X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/52cc3b912c703c24bc90e67aaf24e8ad912d3ebf..e8e0182d65a74b1a222127eb8b36f31a906b14c8:/src/models/resource.ts diff --git a/src/models/resource.ts b/src/models/resource.ts index 0f5fbc28..7e2127b2 100644 --- a/src/models/resource.ts +++ b/src/models/resource.ts @@ -3,29 +3,89 @@ // SPDX-License-Identifier: AGPL-3.0 export interface Resource { - name: string; - createdAt: string; - modifiedAt: string; uuid: string; ownerUuid: string; + createdAt: string; + modifiedByClientUuid: string; + modifiedByUserUuid: string; + modifiedAt: string; href: string; kind: ResourceKind; + etag: string; +} + +export interface TrashableResource extends Resource { + trashAt: string; + deleteAt: string; + isTrashed: boolean; } export enum ResourceKind { - PROJECT = "project", - COLLECTION = "collection", - PIPELINE = "pipeline", - LEVEL_UP = "", - UNKNOWN = "unknown" + COLLECTION = "arvados#collection", + CONTAINER = "arvados#container", + CONTAINER_REQUEST = "arvados#containerRequest", + GROUP = "arvados#group", + LOG = "arvados#log", + PROCESS = "arvados#containerRequest", + PROJECT = "arvados#group", + REPOSITORY = "arvados#repository", + SSH_KEY = "arvados#authorizedKeys", + USER = "arvados#user", + VIRTUAL_MACHINE = "arvados#virtualMachine", + WORKFLOW = "arvados#workflow", + NONE = "arvados#none" } -export function getResourceKind(itemKind: string) { - switch (itemKind) { - case "arvados#project": return ResourceKind.PROJECT; - case "arvados#collection": return ResourceKind.COLLECTION; - case "arvados#pipeline": return ResourceKind.PIPELINE; +export enum ResourceObjectType { + COLLECTION = '4zz18', + CONTAINER = 'dz642', + CONTAINER_REQUEST = 'xvhdp', + GROUP = 'j7d0g', + LOG = '57u5n', + REPOSITORY = 's0uqq', + USER = 'tpzed', + VIRTUAL_MACHINE = '2x53u', + WORKFLOW = '7fd4e', + SSH_KEY = 'fngyi' +} + +export const RESOURCE_UUID_PATTERN = '.{5}-.{5}-.{15}'; +export const RESOURCE_UUID_REGEX = new RegExp(RESOURCE_UUID_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; default: - return ResourceKind.UNKNOWN; + return undefined; } -} +};