Files
speckle-server/packages/shared/src/core/constants.ts
T
2024-08-06 10:03:22 +02:00

277 lines
8.0 KiB
TypeScript

import { flatMap } from '#lodash'
/**
* Speckle role constants
* - Stream - user roles in the context of a specific stream
* - Server - user roles in the context of the entire server
*/
export const Roles = Object.freeze(<const>{
Stream: {
Owner: 'stream:owner',
Contributor: 'stream:contributor',
Reviewer: 'stream:reviewer'
},
Workspace: {
Admin: 'workspace:admin',
Member: 'workspace:member',
Guest: 'workspace:guest'
},
Server: {
Admin: 'server:admin',
User: 'server:user',
Guest: 'server:guest',
ArchivedUser: 'server:archived-user'
}
})
export const RoleInfo = Object.freeze(<const>{
Stream: {
[Roles.Stream.Owner]: {
title: 'Owner',
description:
'Owners have full access, including deletion rights & access control.'
},
[Roles.Stream.Contributor]: {
title: 'Contributor',
description:
'Contributors can create new branches and commits, but they cannot edit stream details or manage collaborators.'
},
[Roles.Stream.Reviewer]: {
title: 'Reviewer',
description: 'Reviewers can only view (read) the data from this stream.'
}
},
Server: {
[Roles.Server.Admin]: 'Admin',
[Roles.Server.User]: 'User',
[Roles.Server.Guest]: 'Guest',
[Roles.Server.ArchivedUser]: 'Archived'
},
Workspace: {
[Roles.Workspace.Admin]: {
title: 'Admin',
description:
'A role assigned workspace administrators. They have full control over the workspace.'
},
[Roles.Workspace.Member]: {
title: 'Member',
description:
'A role assigned workspace members. They have access to resources in the workspace.'
},
[Roles.Workspace.Guest]: {
title: 'Guest',
description:
'A role assigned workspace guests. Their access to resources in the workspace is limited to resources they have explicit roles on.'
}
}
})
export type ServerRoles = (typeof Roles)['Server'][keyof (typeof Roles)['Server']]
export type WorkspaceRoles =
(typeof Roles)['Workspace'][keyof (typeof Roles)['Workspace']]
export type StreamRoles = (typeof Roles)['Stream'][keyof (typeof Roles)['Stream']]
export type AvailableRoles = ServerRoles | StreamRoles | WorkspaceRoles
/**
* Speckle scope constants
* - Scopes define what kind of access has a user approved for a specific access token
*/
export const Scopes = Object.freeze(<const>{
Streams: {
Read: 'streams:read',
Write: 'streams:write'
},
Profile: {
Read: 'profile:read',
Email: 'profile:email',
Delete: 'profile:delete'
},
Users: {
Read: 'users:read',
Email: 'users:email',
Invite: 'users:invite'
},
Server: {
Stats: 'server:stats',
Setup: 'server:setup'
},
Tokens: {
Read: 'tokens:read',
Write: 'tokens:write'
},
Apps: {
Read: 'apps:read',
Write: 'apps:write'
},
Automate: {
ReportResults: 'automate:report-results'
},
AutomateFunctions: {
Read: 'automate-functions:read',
Write: 'automate-functions:write'
},
Workspaces: {
Create: 'workspace:create',
Read: 'workspace:read',
Update: 'workspace:update',
Delete: 'workspace:delete'
}
})
export type StreamScopes = (typeof Scopes)['Streams'][keyof (typeof Scopes)['Streams']]
export type ProfileScopes = (typeof Scopes)['Profile'][keyof (typeof Scopes)['Profile']]
export type UserScopes = (typeof Scopes)['Users'][keyof (typeof Scopes)['Users']]
export type ServerScopes = (typeof Scopes)['Server'][keyof (typeof Scopes)['Server']]
export type TokenScopes = (typeof Scopes)['Tokens'][keyof (typeof Scopes)['Tokens']]
export type AppScopes = (typeof Scopes)['Apps'][keyof (typeof Scopes)['Apps']]
export type AutomateScopes =
(typeof Scopes)['Automate'][keyof (typeof Scopes)['Automate']]
export type AutomateFunctionScopes =
(typeof Scopes)['AutomateFunctions'][keyof (typeof Scopes)['AutomateFunctions']]
export type WorkspaceScopes =
(typeof Scopes)['Workspaces'][keyof (typeof Scopes)['Workspaces']]
export type AvailableScopes =
| StreamScopes
| ProfileScopes
| UserScopes
| ServerScopes
| TokenScopes
| AppScopes
| AutomateScopes
| AutomateFunctionScopes
| WorkspaceScopes
/**
* All scopes
*/
export const AllScopes = flatMap(Scopes, (v) => Object.values(v))
export type ServerScope = (typeof AllScopes)[number]
export const SourceAppNames = [
'Dynamo',
'Revit',
'AutoCAD',
'Civil3D',
'Blender',
'Rhino',
'Grasshopper',
'Excel',
'Unity',
'Unreal',
'Python',
'.NET',
'IFC',
'QGIS',
'ArcGIS',
'ETABS',
'PowerBI',
'SketchUp',
'SAP2000',
'CSiBridge',
'SAFE',
'Archicad',
'Tekla Structures',
'OpenRoads',
'OpenRail',
'OpenBuildings',
'MicroStation',
'Navisworks',
'Speckle Automate'
] as const
export type SourceAppName = (typeof SourceAppNames)[number]
export type SourceAppDefinition = {
/**
* String to look for in input app names to match them to a specific source app
*/
searchKey: string
/**
* Full name
*/
name: SourceAppName
/**
* Shortened name
*/
short: string
/**
* BG color hex code for badges
*/
bgColor: string
}
export const SourceApps: SourceAppDefinition[] = [
{ searchKey: 'dynamo', name: 'Dynamo', short: 'DYN', bgColor: '#a438b6' },
{ searchKey: 'revit', name: 'Revit', short: 'RVT', bgColor: '#3091e7' },
{ searchKey: 'autocad', name: 'AutoCAD', short: 'ACAD', bgColor: '#f0605e' },
{ searchKey: 'civil', name: 'Civil3D', short: 'C3D', bgColor: '#14c1d7' },
{ searchKey: 'blender', name: 'Blender', short: 'BLEND', bgColor: '#fb9514' },
{ searchKey: 'rhino', name: 'Rhino', short: 'RH', bgColor: '#141414' },
{ searchKey: 'grasshopper', name: 'Grasshopper', short: 'GH', bgColor: '#48974b' },
{ searchKey: 'excel', name: 'Excel', short: 'XLSX', bgColor: '#72c076' },
{ searchKey: 'unity', name: 'Unity', short: 'UNITY', bgColor: '#149e91' },
{ searchKey: 'unreal', name: 'Unreal', short: 'UE', bgColor: '#846256' },
{ searchKey: 'python', name: 'Python', short: 'PY', bgColor: '#fddb45' },
{ searchKey: '.net', name: '.NET', short: '.NET', bgColor: '#8531a9' },
{ searchKey: 'ifc', name: 'IFC', short: 'IFC', bgColor: '#bd2e2e' },
{ searchKey: 'qgis', name: 'QGIS', short: 'QGIS', bgColor: '#70e029' },
{ searchKey: 'arcgis', name: 'ArcGIS', short: 'AGIS', bgColor: '#3a6eff' },
{ searchKey: 'etabs', name: 'ETABS', short: 'ETABS', bgColor: '#6d6d6d' },
{ searchKey: 'powerbi', name: 'PowerBI', short: 'PBI', bgColor: '#ffff96' },
{ searchKey: 'sketchup', name: 'SketchUp', short: 'SKP', bgColor: '#8cb7ff' },
{ searchKey: 'sap', name: 'SAP2000', short: 'SAP', bgColor: '#6d6d6d' },
{ searchKey: 'csibridge', name: 'CSiBridge', short: 'CSIB', bgColor: '#6d6d6d' },
{ searchKey: 'safe', name: 'SAFE', short: 'SAFE', bgColor: '#6d6d6d' },
{ searchKey: 'archicad', name: 'Archicad', short: 'ARCHI', bgColor: '#3091e7' },
{
searchKey: 'teklastructures',
name: 'Tekla Structures',
short: 'TEKLAS',
bgColor: '#3a6eff'
},
{ searchKey: 'openroads', name: 'OpenRoads', short: 'OROAD', bgColor: '#846256' },
{ searchKey: 'openrail', name: 'OpenRail', short: 'ORAIL', bgColor: '#846256' },
{
searchKey: 'openbuildings',
name: 'OpenBuildings',
short: 'OBUILD',
bgColor: '#846256'
},
{
searchKey: 'microstation',
name: 'MicroStation',
short: 'MICRO',
bgColor: '#846256'
},
{ searchKey: 'navisworks', name: 'Navisworks', bgColor: '#3e8742', short: 'NAVIS' },
{
searchKey: 'automate',
name: 'Speckle Automate',
bgColor: '#f85c56',
short: 'ATMAT'
}
]
export const WebhookTriggers = Object.freeze(<const>{
StreamUpdate: 'stream_update',
StreamDelete: 'stream_delete',
BranchCreate: 'branch_create',
BranchUpdate: 'branch_update',
BranchDelete: 'branch_delete',
CommitCreate: 'commit_create',
CommitUpdate: 'commit_update',
CommitReceive: 'commit_receive',
CommitDelete: 'commit_delete',
CommentCreated: 'comment_created',
CommentArchived: 'comment_archived',
CommentReplied: 'comment_replied',
StreamPermissionsAdd: 'stream_permissions_add',
StreamPermissionsRemove: 'stream_permissions_remove'
})