Permission: Permission Management
App front end can obtain and check related permissions. If the deactive
state App has permission to change, it cannot be obtained through the permission
event.
The EdgerOS permission object contains the following members (different versions of EdgerOS may be different):
Edger system permissions
ainn
{Boolean} Whether AI Neural Network Computing is allowed.alarm
{Boolean} Is there permission to add alarms.share
{Boolean} Whether this app allows to share of information with other apps.notify
{Boolean} Whether this app allows to push messages.advnwc
{Boolean} Whether this app allows advanced network control.network
{Boolean} Whether this app allows network communication.display
{Boolean} Whether this app allows the use of display output.rtsp
{Boolean} Whether this app allows RTSP network, such as Webcam, Network microphone.lora
{Boolean} Whether this app allows to send or receive data via LoRaWAN network.coap
{Boolean} Whether this app allows CoAP IoT network protocol.wallpaper
{Boolean} Whether this app allows wallpaper settings.account
{Boolean} Whether to allow applications to get the user and group lists.printer
{Boolean} Whether this app allows to use printer.auxstorage
{Boolean} Whether this app allows to use auxiliary storage.vpn
{Boolean} Whether this app allows to create and manage VPN networks (temporarily closed).mqtt
{Object} MQTT Client sub object.publish
{Boolean} Whether to allow applications to publish data using the MQTT protocol.subscribe
{Boolean} Whether to allow applications to subscribe to messages using the MQTT protocol.
mediacenter
{Object} Media Center access permission.readable
{Boolean} Can read media center content.writable
{Boolean} Can write media center content.removable
{Boolean} Can remove media center content.
Terminal device permissions
devices
{Array} List of allowed device IDs.
Terminal native permissions
phone
{Object} Mobile phone features.camera
{Boolean} Mobile phone camera.contacts
{Boolean} Mobile phone contacts.microphone
{Boolean} Mobile phone microphone and midi input.geolocation
{Boolean} Mobile phone geolocation.media
{Boolean} Mobile phone album.file
{Boolean} Mobile phone file.browser
{Boolean} Whether to allow applications to open the browser.
Vehicle permissions
vehicle
{Object} Vehicle features.media
{Boolean} Audio-visual entertainment system.geolocation
{Boolean} Vehicle geolocation.diagnostic
{Boolean} Vehicle diagnostic information.cockpit
{Boolean} Cockpit controls, such as air conditioning, car windows.drive
{Boolean} Driving and autonomous driving related functions.
Developers can determine whether these permissions work in the EdgerOS mobile App environment through the following code:
edger.env().then(data => {
if (data.env === 'edgerapp') {
// We work in EdgerOS mobile App environment.
}
}).catch(error => {
console.error(error);
});
Functions
edger.permission.request(option)
option
{Object} List of permissions to be obtained.- Returns: {Promise} Promise object.
Requesting EdgerOS administor to activate the specified permissions for the current App.
option
must contain the following members:
type
{String} Permission types:permissions
,devices
,phone
orvehicle
. Currently, thevehicle
type is not supported.code
{Array} List of requested permission codes.
The corresponding table of permission request type and code is as follows:
type | code |
---|---|
permissions | ainn , alarm , share , notify , advnwc , network , display , rtsp , lora , coap , wallpaper , account , printer , auxstorage , vpn , mqtt.publish , mqtt.subscribe , mediacenter.readable , mediacenter.writable , mediacenter.removable |
devices | List of allowed device IDs |
phone | camera , microphone , geolocation , browser , media , file , contacts |
vehicle | media , geolocation , diagnostic , cockpit , drive |
The code
array is an array of strings, for example:
['ainn']
Requesting AI computing support.['network', 'notify', 'mediacenter.readable']
Requesting three permissions: network communication, message notification and media center read.
This function can only pop up the permission reminder dialog box, and it cannot guarantee that the EdgerOS user grants permission.
Example
// Apply for edger system permission
edger.permission.request({
code: ['network', 'notify', 'mediacenter.readable'],
type: 'permissions'
}).then((data) => {
// data.success is 'true' means pops up successfully
}).catch(error => {
console.error(error);
});
// Apply for terminal native permission
edger.permission.request({
code: ['camera', `microphone`, 'geolocation'],
type: 'phone'
}).then((data) => {
// data.success is 'true' means pops up successfully
}).catch(error => {
console.error(error);
});
edger.permission.fetch([params])
params
{Array} List of type permissions to be fetched. Optional.- Returns: {Promise} Promise object. When
params
is null or undefined, will return all permission results, otherwise will return depend onparams
.
params
is an array, each element must contain the following members:
type
{String} Permission types:permissions
,devices
,phone
orvehicle
. Currently, thevehicle
type is not supported.code
{Array} List of requested permission codes.
The corresponding table of permission request type and code is as follows:
type | code |
---|---|
permissions | ainn , alarm , share , notify , advnwc , network , display , rtsp , lora , coap , wallpaper , account , printer , auxstorage , vpn , mqtt.publish , mqtt.subscribe , mediacenter.readable , mediacenter.writable , mediacenter.removable |
devices | List of allowed device IDs. |
phone | camera , microphone , geolocation , browser , media , file , contacts |
vehicle | media , geolocation , diagnostic , cockpit , drive |
The code
array is an array of strings, for example:
['ainn']
Requesting AI computing support.['network', 'notify', 'mediacenter.readable']
Requesting three permissions: network communication, message notification and media center read.
Fetch current App permission table.
Example
const params = [
{ type: 'devices', code: [] },
{ type: 'phone', code: ['geolocation', 'media'] },
{ type: 'permissions', code: ['mediacenter.readable', 'mqtt.publish', 'share'] }
]
edger.permission.fetch(params).then((data) => {
// data contains a complete permission table
if (data.share) {
console.log('We have share permission');
}
if (data.mediacenter.readable) {
console.log('We have mediacenter.readable permission');
}
if (data.devices.includes('xxxx')) {
console.log('We have device xxx permission');
}
}).catch(error => {
console.error(error);
});
edger.permission.open()
- Returns: {Promise} Promise object.
Obtain the current mobile phone system permission settings.
Example
edger.permission.open().then(() => {
console.log('Open mobile system permission setting success');
}).catch(error => {
console.error(error);
});
Events
The unified event listener provided by Web-SDK:
const listener = (payload) => {
// Event handling...
}
// add listener
edger.addEventListener('some-event', listener);
// or
// onAction() is an alias of addEventListener().
edger.onAction('some-event', listener);
// remove listener
edger.removeEventListener('some-event', listener);
// remove all listeners
edger.removeAllListeners();
permission
When permission changes, EdgerOS will send this event, and developers need to listen to this event to get the latest permission status.
Example
const listener = (payload) => {
// This data is same with edger.permission.fetch()
if (data.share) {
console.log('We have share permission');
}
}
edger.addEventListener('permission', listener);
Example
Developers can request permissions in the following ways:
const weWantPerms = ['network', 'notify'];
const weHavePerms = false;
// Try to apply for permission
async function request() {
const remind = [];
const perm = await edger.permission.fetch();
for (let code of weWantPerms) {
if (!perm[code]) {
remind.push(code);
}
}
// Some of the permissions we need do not exist
if (remind.length) {
const ret = await edger.permission.request({
code: weWantPerms,
type: 'permissions'
});
if (!ret.success) {
// Here you can remind users to set related permissions.
// If the user agrees, you can share the message to the setting for permission update
if (/* Waiting for user consent remind */) {
edger.app.open({
id: 'com.acoinfo.setting'
}, {
type: 'app-permission', msg: {}
}).then(() => {}).catch(error => {
console.error(error);
});
}
}
} else {
weHavePerms = true;
}
}
// Permission update
const listener = (payload) => {
for (let code of weWantPerms) {
if (!payload[code]) {
weHavePerms = false;
return;
}
}
weHavePerms = true;
}
edger.addEventListener('permission', listener);