Access Restrictions
Skapi database allows you to set access restrictions to records. This allows you to control who can access your records.
You can add additional settings to your table
parameter using an object
instead of a string
in your config.table
. This allows you to set access restrictions to records using the access_group
parameter.
The following values can be set for table.access_group
:
private
: Only the uploader of the record will have access.public
: The record will be accessible to everyone.authorized
: The record will only be accessible to users who are logged into your service.admin
: Only admin can use this group. The record will only be accessible to the admin of your service.
If access_group
is not set, the default value is public
.
TIP
Unless the user is referencing a private access granted record, the user cannot upload a record with access_group
set to higher level than their own access level.
You can read more about referencing records here.
Creating Record With Access Restrictions
Here's an example that demonstrates uploading record with authorized
level access:
let data = {
myData: "Only for authorized users"
};
let config = {
table: {
name: 'ForAuthorizedUsers',
access_group: 'authorized'
}
};
skapi.postRecord(data, config).then(record => {
console.log(record); // Only the logged users will have access this record.
});
Fetching Records with Access Restrictions
In order to fetch records with access_group
that is not public
, you need to specify the access_group
you are trying to fetch from. In this example, we are trying to fetch records from the "ForAuthorizedUsers" table with authorized
access.
let config = {
table: {
name: 'ForAuthorizedUsers',
access_group: 'authorized'
}
};
skapi.getRecords(config)
.then(response => {
// response
/**
* endOfList: true,
* list: [
* {
* data: { myData: "Only for authorized users" },
* table: { name: 'ForAuthorizedUsers', access_group: 'authorized' },
* ...
* }, ...
* ],
* startKey: 'end',
* ...
*/
});
Private Records
Private records are only accessible to the uploader of the record.
Even the admin of the service will not have access to view the user's private data.
The example below demonstrates uploading a private record:
let data = {
myData: "My private data"
};
let config = {
table: {
name: 'PrivateCollection',
access_group: 'private'
}
};
skapi.postRecord(data, config).then(record => {
console.log(record); // Only the uploader will be able to access this record.
});
Then, if someone else tries to fetch the record, they will get an error:
let config = {
record_id: 'record_id_of_the_private_record'
};
skapi.getRecords(config)
.catch(err=>alert(err.message)); // User has no access to private record.
Grant Private Access
Users can grant private access of their record to other users by using the grantPrivateRecordAccess(params)
method.
skapi.grantPrivateRecordAccess({
record_id: 'record_id_of_the_private_record',
user_id: 'user_id_to_grant_access'
})
When the user is granted access to the record, they will be able to fetch the record either if it's private or even if it has higher access group than the user.
Access granted users can also see all the records that is referencing this record at all access groups including private records.
You can read more about referencing records here.
Remove Private Access
Users can remove access of their private record from other users by using the removePrivateRecordAccess(params)
method.
skapi.removePrivateRecordAccess({
record_id: 'record_id_of_the_private_record',
user_id: 'user_id_to_remove_access'
})