A Parse.com REST API client for Node.js
-
Install through npm:
npm install kaiseki
-
Or in your
package.json
:"dependencies": { "kaiseki": "*", ... }
Then:
npm install
- Or you can just download the files and put it in your project.
You might want to read about the REST API first before diving in.
// the class
var Kaiseki = require('kaiseki');
// instantiate
var APP_ID = '<your-Parse-application-id>';
var REST_API_KEY = '<your-Parse-REST-API-key>';
var kaiseki = new Kaiseki(APP_ID, REST_API_KEY);
// use it
kaiseki.getObjects(...);
All callbacks should follow this format: function(error, response, body, success) { ... }
. This is because Kaiseki is based on Request and I thought it would be best to pass the same callback parameters. The error
and response
parameters are passed as is. On most methods, body
is changed and parsed from JSON for your convenience.
-
error: If there's an error during the request (e.g. no internet connection), this will not be empty. Note that if the API returns a
statusCode
that is not2xx
, it is not marked as an error. -
response: You can check lots of info about the request in here. For example, the REST API will return a
response.statusCode
value of4xx
on failures. In these cases, the API will still return a JSON object containing the fieldscode
anderror
. You can get this in thebody
parameter.{ "code": 105, "error": "invalid field name: bl!ng" }
Read more about the Response format here.
-
body: On successful requests, this will be an object or array depending on the method called.
-
success: A convenience parameter, this is a boolean indicating if the request was a success.
This will pass to body
whatever you passed in data
plus the returned createdAt
and sessionToken
fields.
var userInfo = {
// required
username: 'maricris',
password: 'whew',
name: 'Maricris',
gender: 'female',
nickname: 'Kit'
};
kaiseki.createUser(userInfo, function(err, res, body) {
console.log('user created with session token = ', body.sessionToken);
console.log('object id = ', body.objectId);
});
Gets a user info based on the objectId
(user id). The params
is currently unused but is there for a
future use. You can pass in the callback function as the second parameter.
kaiseki.getUser('<object-id>', function(err, res, body) {
console.log('user info = ', body);
});
Log in a user. This will give you a user's sessionToken
that you can use in updateUser
and deleteUser
, and other API calls that may need a sessionToken
.
kaiseki.loginUser('username', 'my secret password', function(err, res, body) {
console.log('user logged in with session token = ', body.sessionToken);
});
Updates a user object (if that wasn't obvious). This requires a sessionToken received from loginUser
or createUser
. If successful, body will contain the updatedAt
value.
kaiseki.sessionToken = 'le session token';
kaiseki.updateUser({name: 'new name'}, function(err, res, body) {
console.log('updated at = ', body.updatedAt);
});
Deletes a user. Like updateUser()
, this needs a sessionToken
.
kaiseki.sessionToken = 'le session token';
kaiseki.deleteUser('<object-id>', function(err, res, body) {
if (res.statusCode == 200)
console.log('deleted!');
else
console.log('failed!');
});
Returns an array of users. The params
parameter can be an object containing the query options as described here. Note that unlike the Parse API Doc, you do not have to pass in strings for the parameter values. This is all taken of for you.
If you do not want to pass in some query parameters, you can set the callback as the first parameter.
The body
in the callback is an array of the returned objects.
// get all users (no parameters)
kaiseki.getUsers(function(err, res, body) {
console.log('all users = ', body);
});
// query with parameters
var params = {
where: { gender: "female" },
order: '-name'
};
kaiseki.getUsers(params, function(err, res, body) {
console.log('female users = ', body);
});
Object methods are similar to the User methods except that Object methods require you to specify the Parse class name. Class names are generally passed as the first parameter.
Creates an object and passes to body
whatever you passed in data
plus the returned createdAt
field.
var dog = {
name: 'Prince',
breed: 'Pomeranian'
};
var className = 'Dogs';
kaiseki.createObject(className, dog, function(err, res, body) {
console.log('object created = ', body);
console.log('object id = ', body.objectId);
});
Gets an object based on the objectId
. The params
is currently unused but is there for a future use. You can pass in the callback function as the second parameter.
kaiseki.getObject('Dogs', '<object-id>', function(err, res, body) {
console.log('found object = ', body);
});
Updates an object. If successful, body will contain the updatedAt
value.
kaiseki.updateObject({name: 'new object name'}, function(err, res, body) {
console.log('object updated at = ', body.updatedAt);
});
Deletes an object. The REST API does not seem to return anything in the body so it's best to check for res.statusCode
if the operation was successful.
kaiseki.deleteObject('<object-id>', function(err, res, body) {
if (res.statusCode == 200)
console.log('deleted!');
else
console.log('failed!');
});
Returns an array of objects in the class name. The params
parameter can be an object containing the query options as described here. Note that unlike the Parse API Doc, you do not have to pass in strings for the parameter values. This is all taken of for you.
If you do not want to pass in some query parameters, you can set the callback as the first parameter.
The body
in the callback is an array of the returned objects.
// get all objects (no parameters)
kaiseki.getObjects('Dogs', function(err, res, body) {
console.log('all dogs = ', body);
});
// query with parameters
var params = {
where: { breed: "Chow Chow" },
order: '-name'
};
kaiseki.getObjects('Dogs', params, function(err, res, body) {
console.log('Chow chow dogs = ', body);
});
Upload a local file. Specifying fileName
is optional. If successful, the body
result will contain the Parse name
and url
of the file. The value of name
is what you will use for associating a Parse file to an object.
var localFilePath = __dirname + '/images/apple.jpg';
kaiseki.uploadFile(localFilePath, function(err, res, body, success) {
console.log('uploaded file url:', body.url);
console.log('uploaded file name:', body.name);
});
This is a more specific upload utility. You can specify the buffer or string to be used as the upload data. The body
result is still the same as uploadFile()
.
var buffer = require('fs').readFileSync(localFilePath);
kaiseki.uploadFileBuffer(buffer, 'image/jpeg', 'orange.jpg', function(err, res, body, success) {
console.log('uploaded file details', body);
});
Uploading a string as a text file:
var buffer = 'my text file contents';
kaiseki.uploadFileBuffer(buffer, 'text/plain', 'readme.txt', function(err, res, body, success) {
console.log('uploaded file details', body);
});
Deleting files require the Parse API master key. The value of name
should be the name generated by Parse during upload.
kaiseki.masterKey = 'your-api-master-key';
var parseFileName = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx-files.apple.jpg';
kaiseki.deleteFile(parseFileName, function(err, res, body, success) {
// body is empty here
if (success)
console.log('successfully deleted file!');
});
Once you have the Parse file name
after calling uploadFile()
or uploadFileBuffer()
, you can attach it to an object by simple setting a "File"
data type to a property. More info here.
var parseFileName = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx-files.apple.jpg';
var apple = {
name: 'Apple',
rotten: true,
photo: {
name: parseFileName,
__type: 'File'
}
};
kaiseki.createObject('Fruits', apple, function(err, res, body, success) {
if (success)
console.log('created an apple object with image');
});
Associating a file to an existing object:
var orange = {
photo: {
name: parseFileName,
__type: 'File'
}
};
kaiseki.updateObject('Fruits', 'the-object-id', orange, function(err, res, body, success) {
if (success)
console.log('attached photo to an object');
});
Send a push notification. 'notification' has to follow the data structure as described in the Parse REST API. The following code sample sends a notification to the broadcast channel (all devices) on all platforms (iOS and Android).
Please note: For push notifications to work you have to configure your Parse app accordingly. Use the 'Settings > Push' section of your app's dashboard.
var notification = {
'channels': [''],
'data': {
"alert": "Tune in for the World Series, tonight at 8pm EDT"
}
};
kaiseki.sendPushNotification(notification, function(err, res, body, success) {
if(success) {
console.log('Push notification successfully sent:', body);
} else {
console.log('Could not send push notification:', err);
}
});
Role methods are similar to the Object methods except that they don't require you to use a classname.
Creates a role and passes to body
whatever you passed in data
plus the returned createdAt
field. You can only create a role if you provide the kaiseki.masterKey
property.
var data = {
name: 'Administrator',
ACL: {
"*": {
"read": true
}
},
roles: {
"__op": "AddRelation",
"objects": [
{
"__type": "Pointer",
"className": "_Role",
"objectId": <role-id>
}
]
},
users: {
"__op": "AddRelation",
"objects": [
{
"__type": "Pointer",
"className": "_User",
"objectId": <user-id>
}
]
}
};
kaiseki.createRole(data, function(err, res, body) {
console.log('role created = ', body);
console.log('object id = ', body.objectId);
});
Gets a role based on the objectId
. The params
is currently unused but is there for a future use. You can pass in the callback function as the second parameter.
kaiseki.getRole('<object-id>', function(err, res, body) {
console.log('found role = ', body);
});
Updates a role. If successful, body will contain the updatedAt
value. You can only update a role if you provide the kaiseki.masterKey
property or the kaiseki.sessionToken
property and if that user has write access to the role.
var data = {
users: {
"__op": "RemoveRelation",
"objects": [
{
"__type": "Pointer",
"className": "_User",
"objectId": <user-id>
}
]
}
};
kaiseki.updateRole(data, function(err, res, body) {
console.log('role updated at = ', body.updatedAt);
});
Deletes a role. The REST API does not return anything in the body so it's best to check for success
if the operation was successful. You can only delete a role if you provide the kaiseki.masterKey
property or the kaiseki.sessionToken
property and if that user has write access to the role.
kaiseki.deleteRole('<object-id>', function(err, res, body, success) {
if (success)
console.log('deleted!');
else
console.log('failed!');
});
Returns an array of roles. The params
parameter can be an object containing the query options as described here. Note that unlike the Parse API Doc, you do not have to pass in strings for the parameter values. This is all taken of for you.
If you do not want to pass in some query parameters, you can set the callback as the first parameter.
The body
in the callback is an array of the returned roles.
// get all objects (no parameters)
kaiseki.getRoles(function(err, res, body) {
console.log('all roles = ', body);
});
// query with parameters
var params = {
where: { name: "Administrator" }
};
kaiseki.getRoles(params, function(err, res, body) {
console.log('Administrator Role = ', body);
});
You can set GeoPoints by simply setting a "GeoPoint"
data type to a property named "location"
.
var place = {
name: 'Tokyo Coffee Shop',
location: {
__type: 'GeoPoint',
latitude: 40.0,
longitude: -30.0
}
};
kaiseki.createObject('Places', place, function(err, res, body, success) {
if (success)
console.log('Created a place with a GeoPoint.');
});
The tests use mocha and have to be run on an empty Parse application. Please provide your own API keys in test/config.js
. To run the test:
make mocha