X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e5e090c801a015f04c04327a176faf54ba3650b7..d1c2611350e47527730f6d3b226b998abf15a607:/src/models/resource.ts diff --git a/src/models/resource.ts b/src/models/resource.ts index 4d2d92e0..fd867277 100644 --- a/src/models/resource.ts +++ b/src/models/resource.ts @@ -14,6 +14,14 @@ export interface Resource { etag: string; } +export interface ResourceWithProperties extends Resource { + properties: any; +} + +export interface EditableResource extends Resource { + isEditable: boolean; +} + export interface TrashableResource extends Resource { trashAt: string; deleteAt: string; @@ -21,12 +29,13 @@ export interface TrashableResource extends Resource { } export enum ResourceKind { + 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", @@ -39,22 +48,25 @@ export enum ResourceKind { } 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' + KEEP_SERVICE = 'bi6l4' } -export const RESOURCE_UUID_PATTERN = '.{5}-.{5}-.{15}'; -export const RESOURCE_UUID_REGEX = new RegExp(RESOURCE_UUID_PATTERN); +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); @@ -91,9 +103,12 @@ export const extractUuidKind = (uuid: string = '') => { 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: - return undefined; + const match = COLLECTION_PDH_REGEX.exec(uuid); + return match ? ResourceKind.COLLECTION : undefined; } };