This is the official CloudBackend SDK for JavaScript, available for browsers and mobile devices, or Node.js backends. It is actively maintained by AppDrag directly. AppDrag is a Cloud CMS & Backend made for web professionals and hosted on Amazon AWS. With AppDrag produce 5 times faster websites, blog e-commerce, Databases & API's.
- Cloud Database: Execute SQL Queries and Non-queries
- Cloud FileSystem: Write & upload files, create/rename/delete/list files and folders
Once the package is installed your can require it and Initialize it with your API Key & AppID. You can find your AppID and API Key in CloudBackend Portal:
- Go to https://prod.appdrag.com/cloudbackend.html
- Login if you are not already logged in, or create a free account
- Select an existing project or create a new one
- In the left menu click on API
- There you will find your AppID in the top left corner, and the APIKey will appear when you press the APIKey button
The preferred way to install the CloudBackend SDK for Node.js is to use the npm package manager for Node.js. Simply type the following into a terminal window:
$ npm install appdrag-cloudbackend
If your are inside a cloud function in CloudBackend, click on the "Open library manager" button then check the last checkbox named "appdrag-cloudbackend" then save.
var cloudbackend = require('appdrag-cloudbackend');
// INIT FROM CODE VARIABLES
cloudbackend.init('your_api_key', 'your_app_id');
// INIT FROM ENVIRONMENT VARIABLES
cloudbackend.init(process.env.APIKEY, process.env.APPID);
cloudbackend.sqlSelect("SELECT * FROM Products WHERE category = 'Software'")
.then( function(response) {
console.log(response);
});
If you want to compose the final SQL query by yourself you must escape the input parameters with cloudbackend.escape() like this:
cloudbackend.sqlSelect("SELECT * FROM Products WHERE category = " + cloudbackend.escape( event.POST.category ))
.then( function(response) {
console.log(response);
});
You can use ? characters as placeholders for values you would like to have escaped. Multiple placeholders are mapped to values in the same order as passed.
cloudbackend.sqlSelect("SELECT * FROM Products WHERE category = ? and id > ?", ["Software", 500])
.then( function(response) {
console.log(response);
});
cloudbackend.sqlExecuteRawQuery("UPDATE Products SET qty = qty - 1, lastUpdate = NOW() WHERE id = 54").then( function(response) {
console.log(response);
});
cloudbackend.sqlExecuteRawQuery("UPDATE Products SET title = ?, lastUpdate = NOW() WHERE id = ?", ["Great product title", 42]).then( function(response) {
console.log(response);
});
You can also use sqlExecuteRawQuery to create tables, add an index or anything you can do with a regular MySQL database.
cloudbackend.sendEmail("[email protected]", "John Doe", "[email protected]", "Hello", "How are you?", false)
.then(function(response) {
console.log(response);
});
var request = require('request').defaults({ encoding: null });
var imgURL = "https://upload.wikimedia.org/wikipedia/en/0/0b/Nickelodeon_SpongeBob_SquarePants_Characters_Cast.png";
request.get(imgURL, function (err, res, body) {
var attachments =[{
filename : "mypicture.jpg",
content: body
}];
var replyTo = [{
email : "[email protected]",
name : "Johnny Doe"
}];
cloudbackend.sendEmailAdvanced("[email protected]", "John Doe", "[email protected]", "[email protected];[email protected];[email protected]", "[email protected]", "Hello", "How are you?", attachments, false, replyTo)
.then(function(response) {
console.log(response);
});
});
cloudbackend.newslettersInsertContactsIntoLists('my list', [{
email : '[email protected]',
firstName : 'john',
lastName : 'doe'
}]).then(
function (response) {
console.log(response);
}
);
cloudbackend.newslettersDeleteContactsFromLists('my list', [{
email : '[email protected]'
}]).then(
function (response) {
console.log(response);
}
);
cloudbackend.newslettersDeleteList('my list').then(
function (response) {
console.log(response);
}
);
cloudbackend.newslettersGetFailedMail('2019-01-01').then(
function (response) {
console.log(response);
}
);
cloudbackend.fileTextWrite("mysubfolder/testfile1.html", "this is the content to save")
.then( function(response) {
console.log(response);
});
var request = require('request').defaults({ encoding: null });
var imgURL = "https://upload.wikimedia.org/wikipedia/commons/thumb/a/a9/Macaca_sinica_-_01.jpg/220px-Macaca_sinica_-_01.jpg";
var filename = "test.jpg";
request.get(imgURL, function (err, res, body) {
cloudbackend.fileBinaryWrite(filename, body).then( function(response) {
console.log(response);
});
});
cloudbackend.fileDelete("mysubfolder/testfile1.html")
.then( function(response) {
console.log(response);
});
cloudbackend.fileRename("mysubfolder/testfile1.html", "mysubfolder/testfile2.html")
.then( function(response) {
console.log(response);
});
cloudbackend.fileCopy("mysubfolder/testfile1.html", "mysubfolder/testfile2.html")
.then( function(response) {
console.log(response);
});
This special function must be called to save a file uploaded to a cloud function in the CloudBackend storage for that AppID. in the destkey you can either indicate a destination path of your choice or use the original filename.
cloudbackend.fileSaveUploaded( event["FILES"][0]["path"], "newfilename.jpg").then( function(response) {
console.log(response);
});
Download a remote file from it's URL and save it inside CloudBackend filesystem
cloudbackend.downloadRemoteFile("https://cf.appdrag.com/cloudbackend/assets/AppDrag-Cloudbackend-API-NPM-Manager.jpg", "img1.jpg").then( function(response) {
console.log(response);
});
Create a subfolder at directoryPath (can contains subdirectories like subdir1/subdir2/...)
cloudbackend.directoryCreate("subfolder1").then( function(response) {
console.log(response);
});
List all files and subdirectories of the specified directoryPath
cloudbackend.directoryList("subfolder1").then( function(response) {
console.log(response);
});
cloudbackend.directoryRename("subfolder1", "subfolder2").then( function(response) {
console.log(response);
});
cloudbackend.directoryDelete("subfolder1")
.then( function(response) {
console.log(response);
});
Post your issues or suggestions here on Github
You can also check our documentation here: https://support.appdrag.com