X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/969254757ab4c21840faedf2bd1e4297c35203ac..b3ffad71aa43fcb8db2d2c7a20ee0ef588e37e04:/src/models/resource.ts?ds=sidebyside diff --git a/src/models/resource.ts b/src/models/resource.ts index 4c198fb8..679a800a 100644 --- a/src/models/resource.ts +++ b/src/models/resource.ts @@ -1,27 +1,88 @@ +// 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 TrashableResource extends Resource { + trashAt: string; + deleteAt: string; + isTrashed: boolean; } export enum ResourceKind { - PROJECT = "project", - COLLECTION = "collection", - PIPELINE = "pipeline", - LEVEL_UP = "levelup", - 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', +} + +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; default: - return ResourceKind.UNKNOWN; + return undefined; } -} +};