Internet-programming_PIbd-2.../Library/js/lines-rest-api.js

119 lines
4.1 KiB
JavaScript
Raw Normal View History

2023-11-30 18:35:42 +04:00
// модуль для работы с REST API сервера
// адрес сервера
const serverUrl = "http://localhost:8081";
2023-12-04 16:13:04 +04:00
// обращение к серверу для получения списка авторов (get)
2023-12-02 17:50:30 +04:00
export async function getAllAuthors() {
2023-11-30 18:35:42 +04:00
const response = await fetch(`${serverUrl}/authors`);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
2023-12-02 17:50:30 +04:00
// обращение к серверу для получения всех категорий книг (get)
export async function getAllCategories() {
const response = await fetch(`${serverUrl}/categories`);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
2023-12-04 16:13:04 +04:00
// обращение к серверу для получения списка авторов и категорий (get)
export async function getAllCategoriesAndAuthors() {
const categoriesPromise = getAllCategories();
const authorsPromise = getAllAuthors();
let responses = await Promise.allSettled([categoriesPromise, authorsPromise]);
responses = responses.map((response) => response.value);
return responses;
}
2023-11-30 18:35:42 +04:00
// обращение к серверу для получения всех записей (get)
2023-12-02 17:50:30 +04:00
export async function getAllBooks() {
const response = await fetch(`${serverUrl}/books?_expand=categories&_expand=authors`);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для получения записи по первичному ключу (id) (get)
// id передается в качестве части пути URL get-запроса
2023-12-02 17:50:30 +04:00
export async function getBook(id) {
const response = await fetch(`${serverUrl}/books/${id}?_expand=categories&_expand=authors`);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для создания записи (post)
// объект отправляется в теле запроса (body)
2023-12-02 19:11:32 +04:00
export async function addBook(categoriesId, name, authorsId, year, image) {
2023-12-02 20:17:24 +04:00
const bookObject = createBookObject(categoriesId, name, authorsId, year, image);
2023-11-30 18:35:42 +04:00
const options = {
method: "POST",
2023-12-02 20:17:24 +04:00
body: JSON.stringify(bookObject),
2023-11-30 18:35:42 +04:00
headers: {
"Accept": "application/json",
"Content-Type": "application/json",
},
};
2023-12-02 19:11:32 +04:00
const response = await fetch(`${serverUrl}/books`, options);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для обновления записи по id (put)
// объект отправляется в теле запроса (body)
// id передается в качестве части пути URL get-запроса
2023-12-02 19:11:32 +04:00
export async function updateBook(id, categoriesId, name, authorsId, year, image) {
2023-12-02 20:17:24 +04:00
const bookObject = createBookObject(categoriesId, name, authorsId, year, image);
2023-11-30 18:35:42 +04:00
const options = {
method: "PUT",
2023-12-02 20:17:24 +04:00
body: JSON.stringify(bookObject),
2023-11-30 18:35:42 +04:00
headers: {
"Accept": "application/json",
"Content-Type": "application/json",
},
};
2023-12-02 19:11:32 +04:00
const response = await fetch(`${serverUrl}/books/${id}`, options);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для удаления записи по id (delete)
// id передается в качестве части пути URL get-запроса
export async function deleteLine(id) {
const options = {
method: "DELETE",
};
2023-12-02 19:11:32 +04:00
const response = await fetch(`${serverUrl}/books/${id}`, options);
2023-11-30 18:35:42 +04:00
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
2023-12-02 17:50:30 +04:00
// функция возвращает объект нужной структуры для отправки на сервер
2023-12-02 19:11:32 +04:00
function createBookObject(categoriesId, name, authorsId, year, image) {
2023-12-02 17:50:30 +04:00
return {
2023-12-02 19:11:32 +04:00
categoriesId,
authorsId,
2023-12-02 17:50:30 +04:00
name,
year,
image,
};
}