X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/a886877017be6744b38d84d52503d21892704139..b6ac7fe88d347582d39fffa002e300af222c578f:/src/models/resource.ts diff --git a/src/models/resource.ts b/src/models/resource.ts index 2d72fbcd..371278e5 100644 --- a/src/models/resource.ts +++ b/src/models/resource.ts @@ -10,15 +10,105 @@ export interface Resource { modifiedByUserUuid: string; modifiedAt: string; href: string; - kind: string; + kind: ResourceKind; etag: string; } +export interface EditableResource extends Resource { + isEditable: boolean; +} + +export interface TrashableResource extends Resource { + trashAt: string; + deleteAt: string; + isTrashed: boolean; +} + export enum ResourceKind { - Collection = "arvados#collection", - ContainerRequest = "arvados#containerRequest", - Group = "arvados#group", - Process = "arvados#containerRequest", - Project = "arvados#group", - Workflow = "arvados#workflow" + API_CLIENT_AUTHORIZATION = "arvados#apiClientAuthorization", + COLLECTION = "arvados#collection", + CONTAINER = "arvados#container", + CONTAINER_REQUEST = "arvados#containerRequest", + GROUP = "arvados#group", + LINK = "arvados#link", + LOG = "arvados#log", + NODE = "arvados#node", + PROCESS = "arvados#containerRequest", + PROJECT = "arvados#group", + REPOSITORY = "arvados#repository", + SSH_KEY = "arvados#authorizedKeys", + KEEP_SERVICE = "arvados#keepService", + USER = "arvados#user", + VIRTUAL_MACHINE = "arvados#virtualMachine", + WORKFLOW = "arvados#workflow", + NONE = "arvados#none" +} + +export enum ResourceObjectType { + API_CLIENT_AUTHORIZATION = 'gj3su', + COLLECTION = '4zz18', + CONTAINER = 'dz642', + CONTAINER_REQUEST = 'xvhdp', + GROUP = 'j7d0g', + LINK = 'o0j2j', + LOG = '57u5n', + REPOSITORY = 's0uqq', + USER = 'tpzed', + VIRTUAL_MACHINE = '2x53u', + WORKFLOW = '7fd4e', + SSH_KEY = 'fngyi', + KEEP_SERVICE = 'bi6l4', + NODE = '7ekkf' } + +export const RESOURCE_UUID_PATTERN = '[a-z0-9]{5}-[a-z0-9]{5}-[a-z0-9]{15}'; +export const PORTABLE_DATA_HASH_PATTERN = '[a-f0-9]{32}\\+\\d+'; +export const RESOURCE_UUID_REGEX = new RegExp("^" + RESOURCE_UUID_PATTERN + "$"); +export const COLLECTION_PDH_REGEX = new RegExp("^" + PORTABLE_DATA_HASH_PATTERN + "$"); + +export const isResourceUuid = (uuid: string) => + RESOURCE_UUID_REGEX.test(uuid); + +export const extractUuidObjectType = (uuid: string) => { + const match = RESOURCE_UUID_REGEX.exec(uuid); + return match + ? match[0].split('-')[1] + : undefined; +}; + +export const extractUuidKind = (uuid: string = '') => { + const objectType = extractUuidObjectType(uuid); + switch (objectType) { + case ResourceObjectType.USER: + return ResourceKind.USER; + case ResourceObjectType.GROUP: + return ResourceKind.GROUP; + case ResourceObjectType.COLLECTION: + return ResourceKind.COLLECTION; + case ResourceObjectType.CONTAINER_REQUEST: + return ResourceKind.CONTAINER_REQUEST; + case ResourceObjectType.CONTAINER: + return ResourceKind.CONTAINER; + case ResourceObjectType.LOG: + return ResourceKind.LOG; + case ResourceObjectType.WORKFLOW: + return ResourceKind.WORKFLOW; + case ResourceObjectType.VIRTUAL_MACHINE: + return ResourceKind.VIRTUAL_MACHINE; + case ResourceObjectType.REPOSITORY: + return ResourceKind.REPOSITORY; + case ResourceObjectType.SSH_KEY: + return ResourceKind.SSH_KEY; + case ResourceObjectType.KEEP_SERVICE: + return ResourceKind.KEEP_SERVICE; + case ResourceObjectType.NODE: + return ResourceKind.NODE; + case ResourceObjectType.API_CLIENT_AUTHORIZATION: + return ResourceKind.API_CLIENT_AUTHORIZATION; + case ResourceObjectType.LINK: + return ResourceKind.LINK; + default: + const match = COLLECTION_PDH_REGEX.exec(uuid); + return match ? ResourceKind.COLLECTION : undefined; + } +};