Files
speckle-server/packages/server/modules/core/roles.js
T
2021-03-15 10:04:30 +00:00

54 lines
1.4 KiB
JavaScript

'use strict'
// Conventions:
// "weight: 1000" => resource owner
// "weight: 100" => resource viewer / basic user
// Anything in between 100 and 1000 can be used for escalating priviliges.
module.exports = [
/**
* Roles for "this" server.
*/
{
name: 'server:admin',
description: 'Holds supreme autocratic authority, not restricted by written laws, legislature, or customs.',
resourceTarget: 'server',
aclTableName: 'server_acl',
weight: 1000,
public: false
},
{
name: 'server:user',
description: 'Has normal access to the server.',
resourceTarget: 'server',
aclTableName: 'server_acl',
weight: 100,
public: false
},
/**
* Roles for streams.
*/
{
name: 'stream:owner',
description: 'Owners have full access, including deletion rights & access control.',
resourceTarget: 'streams',
aclTableName: 'stream_acl',
weight: 1000,
public: true
}, {
name: 'stream:contributor',
description: 'Contributors can create new branches and commits, but they cannot edit stream details or manage collaborators.',
resourceTarget: 'streams',
aclTableName: 'stream_acl',
weight: 500,
public: true
}, {
name: 'stream:reviewer',
description: 'Reviewers can only view (read) the data from this stream.',
resourceTarget: 'streams',
aclTableName: 'stream_acl',
weight: 100,
public: true
}
]