X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/1a9eb2261e6030ba78078e2a206bad27653f2475..8e54bebd8a2e59318e50d7dd26ba1b71e1fe20ab:/src/models/resource.ts diff --git a/src/models/resource.ts b/src/models/resource.ts index 39b4e915..2d2b9f21 100644 --- a/src/models/resource.ts +++ b/src/models/resource.ts @@ -1,9 +1,115 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// 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: string; + kind: ResourceKind; + 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; + isTrashed: boolean; +} + +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", + 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' } + +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 KEEP_URL_REGEX = new RegExp("^(keep:)?" + 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.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; + } +};