2020-12-29 14:39:47 +01:00
|
|
|
/*
|
|
|
|
Javascript wrapper for the Bludit API
|
|
|
|
*/
|
|
|
|
|
2020-11-01 11:55:34 +01:00
|
|
|
class API {
|
|
|
|
|
2020-12-29 14:39:47 +01:00
|
|
|
constructor(apiURL, apiToken, apiAuth) {
|
2021-03-04 16:00:54 +01:00
|
|
|
this.apiURL = "http://localhost:8000/api/";
|
2020-12-29 14:39:47 +01:00
|
|
|
this.body = {
|
|
|
|
token: '45643a4071fad6a12261bb0763550feb',
|
2021-03-04 16:00:54 +01:00
|
|
|
authentication: '02707c99183896203b41d4a9b5c42692'
|
2020-12-29 14:39:47 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-12 21:46:42 +01:00
|
|
|
async getPage(args) {
|
|
|
|
var url = this.apiURL + "pages/" + args['pageKey'];
|
|
|
|
var parameters = "?token=" + this.body.token + "&authentication=" + this.body.authentication;
|
|
|
|
try {
|
|
|
|
const response = await fetch(url + parameters, {
|
|
|
|
method: "GET"
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
|
|
|
return json;
|
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-01 23:13:01 +01:00
|
|
|
async createPage(args={}) {
|
2020-12-29 14:39:47 +01:00
|
|
|
var url = this.apiURL + "pages";
|
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "POST",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2020-12-29 14:39:47 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-01 23:13:01 +01:00
|
|
|
/* Save page fields
|
2020-12-29 14:39:47 +01:00
|
|
|
|
|
|
|
@args['pageKey'] string Page key from the page to edit
|
|
|
|
@args array Arguments can be any of the fields from a page
|
2021-01-23 22:19:47 +01:00
|
|
|
@return string New page key
|
2020-12-29 14:39:47 +01:00
|
|
|
*/
|
|
|
|
async savePage(args) {
|
|
|
|
var url = this.apiURL + "pages/" + args['pageKey'];
|
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "PUT",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2020-12-29 14:39:47 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-01 23:13:01 +01:00
|
|
|
/* Generates unique slug text for the a page
|
2020-12-29 14:39:47 +01:00
|
|
|
|
|
|
|
@args['pageKey'] string Page key for the page to generate the slug url
|
|
|
|
@args['text'] string Text that you want to generate the slug url
|
|
|
|
@args['parentKey'] string Parent page key if the page has one, if not empty string
|
2021-01-23 22:19:47 +01:00
|
|
|
@return string Slug text
|
2020-12-29 14:39:47 +01:00
|
|
|
*/
|
|
|
|
async friendlyURL(args) {
|
|
|
|
var url = this.apiURL + "helper/friendly-url/";
|
|
|
|
var parameters = "?token=" + this.body.token + "&authentication=" + this.body.authentication;
|
|
|
|
parameters = parameters + "&pageKey=" + args['pageKey'];
|
|
|
|
parameters = parameters + "&text=" + args['text'];
|
|
|
|
parameters = parameters + "&parentKey=" + args['parentKey'];
|
|
|
|
try {
|
|
|
|
const response = await fetch(url + parameters, {
|
|
|
|
method: "GET"
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2020-12-29 14:39:47 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-01 23:13:01 +01:00
|
|
|
/* Get all files uploaded for the page
|
2020-12-29 14:39:47 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args string
|
|
|
|
@return array
|
2020-12-29 14:39:47 +01:00
|
|
|
*/
|
|
|
|
async getPageFiles(args) {
|
2021-01-23 22:19:47 +01:00
|
|
|
var url = this.apiURL + "pages/files/" + args['pageKey'];
|
2020-12-29 14:39:47 +01:00
|
|
|
var parameters = "?token=" + this.body.token + "&authentication=" + this.body.authentication;
|
|
|
|
try {
|
|
|
|
const response = await fetch(url + parameters, {
|
|
|
|
method: "GET"
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-12 21:46:42 +01:00
|
|
|
return json;
|
2020-12-29 14:39:47 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Save settings
|
2020-12-29 14:39:47 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Arguments can be any of the fields from settings
|
|
|
|
@return array
|
2021-01-01 23:13:01 +01:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
async saveSettings(args) {
|
|
|
|
var url = this.apiURL + "settings";
|
2021-01-01 23:13:01 +01:00
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
2021-01-23 22:19:47 +01:00
|
|
|
method: "PUT",
|
2021-01-01 23:13:01 +01:00
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2021-01-01 23:13:01 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2020-12-29 14:39:47 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Create a new category
|
2021-01-01 23:13:01 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Arguments can be any of the fields from a category
|
|
|
|
@return string New category key
|
2020-12-29 14:39:47 +01:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
async createCategory(args) {
|
|
|
|
var url = this.apiURL + "categories";
|
2020-12-29 14:39:47 +01:00
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
2021-01-23 22:19:47 +01:00
|
|
|
method: "POST",
|
2020-12-29 14:39:47 +01:00
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2020-12-29 14:39:47 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2020-11-30 22:00:54 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Edit a category
|
2021-01-12 21:46:42 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Arguments can be any of the fields from a category
|
|
|
|
@return string The category key
|
2021-01-12 21:46:42 +01:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
async editCategory(args) {
|
|
|
|
var url = this.apiURL + "categories/" + args['key'];
|
2021-01-12 21:46:42 +01:00
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
2021-01-23 22:19:47 +01:00
|
|
|
method: "PUT",
|
2021-01-12 21:46:42 +01:00
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2021-01-12 21:46:42 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Delete a category
|
2021-01-16 13:03:16 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Array => (key: string)
|
|
|
|
@return string The category key deleted
|
2021-01-16 13:03:16 +01:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
async deleteCategory(args) {
|
2021-01-16 13:03:16 +01:00
|
|
|
var url = this.apiURL + "categories/" + args['key'];
|
2021-01-23 22:19:47 +01:00
|
|
|
var body = this.body;
|
2021-01-16 13:03:16 +01:00
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
2021-01-23 22:19:47 +01:00
|
|
|
method: "DELETE",
|
2021-01-16 13:03:16 +01:00
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2021-01-16 13:03:16 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Delete the profile picture from a user
|
2021-01-16 13:03:16 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Array => (username: string)
|
|
|
|
@return string The username
|
2021-01-16 13:03:16 +01:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
async deleteProfilePicture(args) {
|
|
|
|
var url = this.apiURL + "users/picture/" + args['username'];
|
2021-01-16 13:03:16 +01:00
|
|
|
var body = this.body;
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "DELETE",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
2021-01-16 13:03:16 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-12 21:46:42 +01:00
|
|
|
/* Create a new user
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@args array Arguments can be any of the fields from a user
|
|
|
|
@return string Returns the username created
|
2021-01-12 21:46:42 +01:00
|
|
|
*/
|
|
|
|
async createUser(args) {
|
|
|
|
var url = this.apiURL + "users";
|
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "POST",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
2021-01-23 22:19:47 +01:00
|
|
|
return json;
|
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-26 22:31:12 +01:00
|
|
|
/* Edit an user
|
2021-01-23 22:19:47 +01:00
|
|
|
|
2021-01-26 22:31:12 +01:00
|
|
|
@args array Arguments can be any of the fields from an user
|
2021-01-23 22:19:47 +01:00
|
|
|
@return string The username
|
|
|
|
*/
|
2021-01-26 22:31:12 +01:00
|
|
|
async editUser(args) {
|
|
|
|
var url = this.apiURL + "users/" + args['username'];
|
2021-01-23 22:19:47 +01:00
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "PUT",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
|
|
|
return json;
|
2021-01-12 21:46:42 +01:00
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-07 17:19:24 +01:00
|
|
|
/* Install and activate a plugin === Bludit v4
|
|
|
|
|
2021-02-07 18:13:25 +01:00
|
|
|
@args array
|
|
|
|
@return string
|
2021-02-07 17:19:24 +01:00
|
|
|
*/
|
|
|
|
async activatePlugin(args) {
|
|
|
|
var url = this.apiURL + "plugins/" + args['pluginClassName'];
|
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "POST",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
|
|
|
return json;
|
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-07 18:13:25 +01:00
|
|
|
/* Uninstall and deactivate a plugin === Bludit v4
|
|
|
|
|
|
|
|
@args array
|
|
|
|
@return string
|
|
|
|
*/
|
|
|
|
async deactivatePlugin(args) {
|
|
|
|
var url = this.apiURL + "plugins/" + args['pluginClassName'];
|
|
|
|
var body = Object.assign({}, this.body, args);
|
|
|
|
try {
|
|
|
|
var response = await fetch(url, {
|
|
|
|
credentials: "same-origin",
|
|
|
|
method: "DELETE",
|
|
|
|
body: JSON.stringify(body),
|
|
|
|
headers: new Headers({
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
})
|
|
|
|
});
|
|
|
|
var json = await response.json();
|
|
|
|
return json;
|
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-30 22:00:54 +01:00
|
|
|
}
|