Anime Spotlight API is a backend service designed to support the Anime Spotlight web application, offering a comprehensive suite of CRUD RESTful APIs for managing anime data. Built with Node.js and Express.js, the service enhances simplicity and organized data management by adopting an MVC-like pattern and utilizing a JSON file for data storage.
- CRUD Operations: Supports create, read, update, and delete operations for anime data.
- RESTful Architecture: Designed with REST principles for integration with frontend applications.
- Data Validation: Incorporates thorough request validation to ensure data integrity.
- Error Handling: Implements robust error handling for improved reliability and debugging.
- Node.js
- npm (Node.js package manager)
Clone the repository and install dependencies:
git clone https://github.com/plhsu19/anime-spotlight-api.git
cd anime-spotlight-api
npm install
To start the server in development mode with live reloading, run:
npm run start:dev
This will serve the server on localhost:8080
by default.
For production mode, run:
npm start
Below is a detailed look at the available endpoints and their functionalities, including an example to illustrate how to use the "Get Anime by ID" endpoint.
- Get All Animes (
GET /animes
): Fetches a list of all anime titles. - Get Anime by ID (
GET /animes/:id
): Retrieves detailed information about a specific anime by its ID. - Create New Anime (
POST /animes
): Allows the creation of a new anime entry. - Update Existing Anime (
PUT /animes/:id
): Updates the details of an existing anime entry. - Delete Anime (
DELETE /animes/:id
): Removes an anime entry from the system.
Retrieves detailed information about a specific anime by its ID.
To fetch details for an anime with the ID of 10, you would make the following request:
curl --location 'localhost:8080/animes/10'
Example Successful Response (status code: 200)
{
"success": true,
"data": {
"anime": {
"id": 10,
"title": "Example Anime Title",
"enTitle": "Example Anime English Title",
"description": "This is a mock description for an example anime. It includes plot points, character development, and thematic elements that captivate the audience.",
"rating": 8.5,
"startDate": "2021-01-01",
"endDate": "2021-06-01",
"subtype": "TV",
"status": "finished",
"posterImage": "https://example.com/poster_image.jpg",
"coverImage": "https://example.com/cover_image.jpg",
"episodeCount": 24,
"categories": [
"Adventure",
"Fantasy",
"Magic"
]
}
}
}
This example demonstrates how to retrieve and display information for a specific anime using its ID, providing an insight into the type of data returned by the API.
Allows the creation of a new anime entry in the database.
To create a new anime entry, you would make the following request:
curl --location --request POST 'http://localhost:8080/animes' \
--header 'Content-Type: application/json' \
--data '{
"title": "New Anime Title",
"enTitle": "New Anime English Title",
"description": "Description of the new anime, including plot points and character development.",
"rating": 9.0,
"startDate": "2023-01-01",
"endDate": "2023-12-31",
"subtype": "TV",
"status": "upcoming",
"posterImage": "https://example.com/new_poster_image.jpg",
"coverImage": "https://example.com/new_cover_image.jpg",
"episodeCount": 12,
"categories": ["Action", "Adventure", "Fantasy"]
}'
{
"success": true,
"data": {
"anime": {
"id": 11,
"title": "New Anime Title",
"enTitle": "New Anime English Title",
"description": "Description of the new anime, including plot points and character development.",
"rating": 9.0,
"startDate": "2023-01-01",
"endDate": "2023-12-31",
"subtype": "TV",
"status": "upcoming",
"posterImage": "https://example.com/new_poster_image.jpg",
"coverImage": "https://example.com/new_cover_image.jpg",
"episodeCount": 12,
"categories": ["Action", "Adventure", "Fantasy"]
}
}
}
This example demonstrates how to create a new anime entry using the API, providing an insight into the required data structure and the type of response data returned by the API.
Comprehensive error handling for validation errors (400), not found errors (404), and server errors (500), ensuring a smooth user experience.
Example: Requesting with invalid field data:
{
"success": false,
"message": "\"rating\" must be less than or equal to 10, \"status\" must be one of [current, finished, upcoming]"
}
Example: Requesting a non-existent anime ID:
{
"success": false,
"message": "Anime with id 999 was not found"
}
Example: A server-side issue that prevents request processing:
{
"success": false,
"message": "Something went wrong, please try again later or contact support."
}
For ease of development, data is stored in a local JSON file (animes.json
), simulating a database's functionality in a lightweight manner. The Anime.js
model class encapsulates anime entity properties and provides methods for data manipulation, offering an MVC-like model for server interactions.
Contributions are welcome!
- Reporting Bugs: If you encounter any bugs or missing features, please feel free to raise an issue in the repository.
- Making Contributions: If you'd like to contribute:
- Fork the repository.
- Create a new branch for your changes.
- Open a pull request against the main branch when you're ready to submit your changes, and ask for a review.
This project is open source - see the MIT License file for details.
For any inquiries or contributions, please contact Pei-Lun Hsu at peilun.hsu.tw@gmail.com.