Create a bookmark
POST
/api/v1/bookmarks
CURL *hnd = curl_easy_init();
curl_easy_setopt(hnd, CURLOPT_CUSTOMREQUEST, "POST");curl_easy_setopt(hnd, CURLOPT_URL, "http://127.0.0.1:58259/api/v1/bookmarks");
struct curl_slist *headers = NULL;headers = curl_slist_append(headers, "Content-Type: application/json");curl_easy_setopt(hnd, CURLOPT_HTTPHEADER, headers);
curl_easy_setopt(hnd, CURLOPT_POSTFIELDS, "{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }");
CURLcode ret = curl_easy_perform(hnd);using System.Net.Http.Headers;var client = new HttpClient();var request = new HttpRequestMessage{ Method = HttpMethod.Post, RequestUri = new Uri("http://127.0.0.1:58259/api/v1/bookmarks"), Content = new StringContent("{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }") { Headers = { ContentType = new MediaTypeHeaderValue("application/json") } }};using (var response = await client.SendAsync(request)){ response.EnsureSuccessStatusCode(); var body = await response.Content.ReadAsStringAsync(); Console.WriteLine(body);}package main
import ( "fmt" "strings" "net/http" "io")
func main() {
url := "http://127.0.0.1:58259/api/v1/bookmarks"
payload := strings.NewReader("{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }")
req, _ := http.NewRequest("POST", url, payload)
req.Header.Add("Content-Type", "application/json")
res, _ := http.DefaultClient.Do(req)
defer res.Body.Close() body, _ := io.ReadAll(res.Body)
fmt.Println(res) fmt.Println(string(body))
}HttpRequest request = HttpRequest.newBuilder() .uri(URI.create("http://127.0.0.1:58259/api/v1/bookmarks")) .header("Content-Type", "application/json") .method("POST", HttpRequest.BodyPublishers.ofString("{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }")) .build();HttpResponse<String> response = HttpClient.newHttpClient().send(request, HttpResponse.BodyHandlers.ofString());System.out.println(response.body());OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json");RequestBody body = RequestBody.create(mediaType, "{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }");Request request = new Request.Builder() .url("http://127.0.0.1:58259/api/v1/bookmarks") .post(body) .addHeader("Content-Type", "application/json") .build();
Response response = client.newCall(request).execute();import axios from 'axios';
const options = { method: 'POST', url: 'http://127.0.0.1:58259/api/v1/bookmarks', headers: {'Content-Type': 'application/json'}, data: { bookId: 1, cfi: 'example', positionMs: 1, trackIndex: 1, pageNumber: 1, title: 'example', audiobookBookmark: true, pdfBookmark: true }};
try { const { data } = await axios.request(options); console.log(data);} catch (error) { console.error(error);}const url = 'http://127.0.0.1:58259/api/v1/bookmarks';const options = { method: 'POST', headers: {'Content-Type': 'application/json'}, body: '{"bookId":1,"cfi":"example","positionMs":1,"trackIndex":1,"pageNumber":1,"title":"example","audiobookBookmark":true,"pdfBookmark":true}'};
try { const response = await fetch(url, options); const data = await response.json(); console.log(data);} catch (error) { console.error(error);}val client = OkHttpClient()
val mediaType = MediaType.parse("application/json")val body = RequestBody.create(mediaType, "{ \"bookId\": 1, \"cfi\": \"example\", \"positionMs\": 1, \"trackIndex\": 1, \"pageNumber\": 1, \"title\": \"example\", \"audiobookBookmark\": true, \"pdfBookmark\": true }")val request = Request.Builder() .url("http://127.0.0.1:58259/api/v1/bookmarks") .post(body) .addHeader("Content-Type", "application/json") .build()
val response = client.newCall(request).execute()use serde_json::json;use reqwest;
#[tokio::main]pub async fn main() { let url = "http://127.0.0.1:58259/api/v1/bookmarks";
let payload = json!({ "bookId": 1, "cfi": "example", "positionMs": 1, "trackIndex": 1, "pageNumber": 1, "title": "example", "audiobookBookmark": true, "pdfBookmark": true });
let mut headers = reqwest::header::HeaderMap::new(); headers.insert("Content-Type", "application/json".parse().unwrap());
let client = reqwest::Client::new(); let response = client.post(url) .headers(headers) .json(&payload) .send() .await;
let results = response.unwrap() .json::<serde_json::Value>() .await .unwrap();
dbg!(results);}curl --request POST \ --url http://127.0.0.1:58259/api/v1/bookmarks \ --header 'Content-Type: application/json' \ --data '{ "bookId": 1, "cfi": "example", "positionMs": 1, "trackIndex": 1, "pageNumber": 1, "title": "example", "audiobookBookmark": true, "pdfBookmark": true }'wget --quiet \ --method POST \ --header 'Content-Type: application/json' \ --body-data '{ "bookId": 1, "cfi": "example", "positionMs": 1, "trackIndex": 1, "pageNumber": 1, "title": "example", "audiobookBookmark": true, "pdfBookmark": true }' \ --output-document \ - http://127.0.0.1:58259/api/v1/bookmarksCreate a new bookmark for a book.
Request Body required
Section titled “Request Body required ” Media type application/json
Bookmark creation request
object
bookId
required
integer format: int64
cfi
string
positionMs
integer format: int64
trackIndex
integer format: int32
pageNumber
integer format: int32
title
string
audiobookBookmark
boolean
pdfBookmark
boolean
Example generated
{ "bookId": 1, "cfi": "example", "positionMs": 1, "trackIndex": 1, "pageNumber": 1, "title": "example", "audiobookBookmark": true, "pdfBookmark": true}Responses
Section titled “ Responses ”Bookmark created successfully
Media type */*
object
id
integer format: int64
userId
integer format: int64
bookId
integer format: int64
cfi
string
positionMs
integer format: int64
trackIndex
integer format: int32
pageNumber
integer format: int32
title
string
color
string
notes
string
priority
integer format: int32
createdAt
string format: date-time
updatedAt
string format: date-time