refs #master Merge branch 'origin/master' into 14280-query-language
[arvados-workbench2.git] / src / models / resource.ts
index 520520f76eb1d39c65c04378968b9c4de3093e5e..99e9196fc55105b5325aacf3098d4a13fd523d01 100644 (file)
@@ -29,7 +29,9 @@ export enum ResourceKind {
     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"
 }
@@ -42,7 +44,9 @@ export enum ResourceObjectType {
     LOG = '57u5n',
     REPOSITORY = 's0uqq',
     USER = 'tpzed',
+    VIRTUAL_MACHINE = '2x53u',
     WORKFLOW = '7fd4e',
+    SSH_KEY = 'fngyi'
 }
 
 export const RESOURCE_UUID_PATTERN = '.{5}-.{5}-.{15}';
@@ -75,8 +79,31 @@ export const extractUuidKind = (uuid: string = '') => {
             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 undefined;
+    }
+};
+
+export const getResourceKind = (kind?: string) => {
+    switch (kind) {
+        case "arvados#collection":
+            return ResourceKind.COLLECTION;
+        case "arvados#container":
+            return ResourceKind.CONTAINER;
+        case "arvados#containerRequest":
+            return ResourceKind.CONTAINER_REQUEST;
+        case "arvados#group":
+            return ResourceKind.GROUP;
+        case "arvados#log":
+            return ResourceKind.LOG;
+        case "arvados#workflow":
+            return ResourceKind.WORKFLOW;
         default:
             return undefined;
     }