Coder Social home page Coder Social logo

islamicity / bookshelf-api-2 Goto Github PK

View Code? Open in Web Editor NEW

This project forked from zulfikarakbar/bookshelf-api

0.0 1.0 0.0 3.63 MB

Submission Bookshelf API Dicoding

Home Page: https://www.dicoding.com/academies/261/tutorials/14967

JavaScript 100.00%

bookshelf-api-2's Introduction

Submission Bookshelf API

Kriteria 1 : API dapat menyimpan buku

  1. API harus dapat menyimpan buku melalui route:
    Method : POST
    URL : /books
    Body Request:
    {
        "name": string,
        "year": number,
        "author": string,
        "summary": string,
        "publisher": string,
        "pageCount": number,
        "readPage": number,
        "reading": boolean
    }
  1. Objek buku yang disimpan pada server harus memiliki struktur seperti contoh di bawah ini:
    {
        "id": "Qbax5Oy7L8WKf74l",
        "name": "Buku A",
        "year": 2010,
        "author": "John Doe",
        "summary": "Lorem ipsum dolor sit amet",
        "publisher": "Dicoding Indonesia",
        "pageCount": 100,
        "readPage": 25,
        "finished": false,
        "reading": false,
        "insertedAt": "2021-03-04T09:11:44.598Z",
        "updatedAt": "2021-03-04T09:11:44.598Z"
    }
  1. Properti yang ditebalkan diolah dan didapatkan di sisi server. Berikut penjelasannya:

    id : nilai id haruslah unik. Untuk membuat nilai unik, Anda bisa memanfaatkan nanoid.

    finished : merupakan properti boolean yang menjelaskan apakah buku telah selesai dibaca atau belum. Nilai finished didapatkan dari observasi pageCount === readPage.

    insertedAt : merupakan properti yang menampung tanggal dimasukkannya buku. Anda bisa gunakan new Date().toISOString() untuk menghasilkan nilainya.

    updatedAt : merupakan properti yang menampung tanggal diperbarui buku. Ketika buku baru dimasukkan, berikan nilai properti ini sama dengan insertedAt.

  2. Server harus merespons gagal bila:\
    • Client tidak melampirkan properti namepada request body. Bila hal ini terjadi, maka server akan merespons dengan:
      Status Code : 400
      Response Body:
        {
	   "status": "fail",
	   "message": "Gagal menambahkan buku. Mohon isi nama buku"
    	}


- Client melampirkan nilai properti readPage yang lebih besar dari nilai properti pageCount. Bila hal ini terjadi, maka server akan merespons dengan:
Status Code : 400
Response Body:

	{
	  "status": "fail",
	  "message": "Gagal menambahkan buku. readPage tidak boleh lebih besar dari pageCount"
    	}


- Server gagal memasukkan buku karena alasan umum (generic error). Bila hal ini terjadi, maka server akan merespons dengan:
Status Code : 500
Response Body:

    	{
           "status": "error",
           "message": "Buku gagal ditambahkan"
    	}
  1. Bila buku berhasil dimasukkan, server harus mengembalikan respons dengan:
    Status Code : 201
    Response Body:
    {
        "status": "success",
        "message": "Buku berhasil ditambahkan",
        "data": {
            "bookId": "1L7ZtDUFeGs7VlEt"
        }
    }

Kriteria 2 : API dapat menampilkan seluruh buku

  1. API harus dapat menampilkan seluruh buku yang disimpan melalui route:
    Method : GET
    URL: /books

  2. Server harus mengembalikan respons dengan:
    Status Code : 200
    Response Body:
    {
       "status": "success",
       "data": {
          "books": [
           {
             "id": "Qbax5Oy7L8WKf74l",
             "name": "Buku A",
             "publisher": "Dicoding Indonesia"
           },
                
         ]
      }
   }
  1. Jika belum terdapat buku yang dimasukkan, server bisa merespons dengan array books kosong.
    {
      "status": "success",
      "data": {
          "books": []
      }
    }

Kriteria 3 : API dapat menampilkan detail buku

  1. API harus dapat menampilkan seluruh buku yang disimpan melalui route:
    Method : GET
    URL: /books/{bookId}

  2. Bila buku dengan id yang dilampirkan oleh client tidak ditemukan, maka server harus mengembalikan respons dengan:
    Status Code : 404
    Response Body:
    {
      "status": "fail",
      "message": "Buku tidak ditemukan"
    }
  1. Bila buku dengan id yang dilampirkan ditemukan, maka server harus mengembalikan respons dengan:
    Status Code : 200
    Response Body:
    {
      "status": "success",
      "data": {
         "book": {
            "id": "aWZBUW3JN_VBE-9I",
            "name": "Buku A Revisi",
            "year": 2011,
            "author": "Jane Doe",
            "summary": "Lorem Dolor sit Amet",
            "publisher": "Dicoding",
            "pageCount": 200,
            "readPage": 26,
            "finished": false,
            "reading": false,
            "insertedAt": "2021-03-05T06:14:28.930Z",
            "updatedAt": "2021-03-05T06:14:30.718Z"
         }
       }
    }

Kriteria 4 : API dapat mengubah data buku

  1. API yang Anda buat harus dapat mengubah data buku berdasarkan id melalui route:
    Method : PUT
    URL : /books/{bookId}
    Body Request:
    {
        "name": string,
        "year": number,
        "author": string,
        "summary": string,
        "publisher": string,
        "pageCount": number,
        "readPage": number,
        "reading": boolean
  1. Server harus merespons gagal bila:
    Client tidak melampirkan properti name pada request body. Bila hal ini terjadi, maka server akan merespons dengan:
    Status Code : 400
    Response Body:
    {
        "status": "fail",
        "message": "Gagal memperbarui buku. Mohon isi nama buku"
    }
  1. Client melampirkan nilai properti readPage yang lebih besar dari nilai properti pageCount. Bila hal ini terjadi, maka server akan merespons dengan:
    Status Code : 400
    Response Body:
    {
        "status": "fail",
        "message": "Gagal memperbarui buku. readPage tidak boleh lebih besar dari pageCount"
    }
  1. Id yang dilampirkan oleh client tidak ditemukkan oleh server. Bila hal ini terjadi, maka server akan merespons dengan:
    Status Code : 404
    Response Body:
    {
        "status": "fail",
        "message": "Gagal memperbarui buku. Id tidak ditemukan"
    }
  1. Bila buku berhasil diperbarui, server harus mengembalikan respons dengan:
    Status Code : 200
    Response Body:
    {
        "status": "success",
        "message": "Buku berhasil diperbarui"
    }

Kriteria 5 : API dapat menghapus buku

  1. API yang Anda buat harus dapat menghapus buku berdasarkan id melalui route berikut:
    Method : DELETE
    URL: /books/{bookId}


  2. Bila id yang dilampirkan tidak dimiliki oleh buku manapun, maka server harus mengembalikan respons berikut:
    Status Code : 404
    Response Body:
    {
        "status": "fail",
        "message": "Buku gagal dihapus. Id tidak ditemukan"
    }


3. Bila id dimiliki oleh salah satu buku, maka buku tersebut harus dihapus dan server mengembalikan respons berikut:
Status Code : 200
Response Body:

    {
        "status": "success",
        "message": "Buku berhasil dihapus"
    }

bookshelf-api-2's People

Contributors

zulfikarakbar avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.