Merge branch '21128-toolbar-context-menu'
[arvados-workbench2.git] / src / services / groups-service / groups-service.ts
index b69483cb3b2a45e6f74d6b2e0befcfc6753537e4..b9f47df0dbb97e01e7f020c84ebf2eb1139c4339 100644 (file)
@@ -5,16 +5,19 @@
 import { CancelToken } from 'axios';
 import { snakeCase, camelCase } from "lodash";
 import { CommonResourceService } from 'services/common-service/common-resource-service';
-import { ListResults, ListArguments } from 'services/common-service/common-service';
-import { AxiosInstance, AxiosRequestConfig } from "axios";
-import { CollectionResource } from "models/collection";
-import { ProjectResource } from "models/project";
-import { ProcessResource } from "models/process";
-import { WorkflowResource } from "models/workflow";
-import { TrashableResourceService } from "services/common-service/trashable-resource-service";
-import { ApiActions } from "services/api/api-actions";
-import { GroupResource } from "models/group";
-import { Session } from "models/session";
+import {
+    ListResults,
+    ListArguments,
+} from 'services/common-service/common-service';
+import { AxiosInstance, AxiosRequestConfig } from 'axios';
+import { CollectionResource } from 'models/collection';
+import { ProjectResource } from 'models/project';
+import { ProcessResource } from 'models/process';
+import { WorkflowResource } from 'models/workflow';
+import { TrashableResourceService } from 'services/common-service/trashable-resource-service';
+import { ApiActions } from 'services/api/api-actions';
+import { GroupResource } from 'models/group';
+import { Session } from 'models/session';
 
 export interface ContentsArguments {
     limit?: number;
@@ -24,6 +27,7 @@ export interface ContentsArguments {
     recursive?: boolean;
     includeTrash?: boolean;
     excludeHomeProject?: boolean;
+    select?: string[];
 }
 
 export interface SharedArguments extends ListArguments {
@@ -31,30 +35,39 @@ export interface SharedArguments extends ListArguments {
 }
 
 export type GroupContentsResource =
-    CollectionResource |
-    ProjectResource |
-    ProcessResource |
-    WorkflowResource;
-
-export class GroupsService<T extends GroupResource = GroupResource> extends TrashableResourceService<T> {
+    | CollectionResource
+    | ProjectResource
+    | ProcessResource
+    | WorkflowResource;
 
+export class GroupsService<
+    T extends GroupResource = GroupResource
+    > extends TrashableResourceService<T> {
     constructor(serverApi: AxiosInstance, actions: ApiActions) {
-        super(serverApi, "groups", actions);
+        super(serverApi, 'groups', actions);
     }
 
     async contents(uuid: string, args: ContentsArguments = {}, session?: Session, cancelToken?: CancelToken): Promise<ListResults<GroupContentsResource>> {
-        const { filters, order, ...other } = args;
+        const { filters, order, select, ...other } = args;
         const params = {
             ...other,
             filters: filters ? `[${filters}]` : undefined,
-            order: order ? order : undefined
+            order: order ? order : undefined,
+            select: select
+                ? JSON.stringify(select.map(sel => {
+                    const sp = sel.split(".");
+                    return sp.length === 2 ? (sp[0] + "." + snakeCase(sp[1])) : snakeCase(sel);
+                }))
+                : undefined
+        };
+        const pathUrl = (uuid !== '') ? `/${uuid}/contents` : '/contents';
+        const cfg: AxiosRequestConfig = {
+            params: CommonResourceService.mapKeys(snakeCase)(params),
         };
-        const pathUrl = uuid ? `/${uuid}/contents` : '/contents';
 
-        const cfg: AxiosRequestConfig = { params: CommonResourceService.mapKeys(snakeCase)(params) };
         if (session) {
             cfg.baseURL = session.baseUrl;
-            cfg.headers = { 'Authorization': 'Bearer ' + session.token };
+            cfg.headers = { Authorization: 'Bearer ' + session.token };
         }
 
         if (cancelToken) {
@@ -62,24 +75,30 @@ export class GroupsService<T extends GroupResource = GroupResource> extends Tras
         }
 
         const response = await CommonResourceService.defaultResponse(
-            this.serverApi.get(this.resourceType + pathUrl, cfg), this.actions, false
+            this.serverApi.get(this.resourceType + pathUrl, cfg),
+            this.actions,
+            false
         );
 
-        return { ...TrashableResourceService.mapKeys(camelCase)(response), clusterId: session && session.clusterId };
+        return {
+            ...TrashableResourceService.mapKeys(camelCase)(response),
+            clusterId: session && session.clusterId,
+        };
     }
 
-    shared(params: SharedArguments = {}): Promise<ListResults<GroupContentsResource>> {
+    shared(
+        params: SharedArguments = {}
+    ): Promise<ListResults<GroupContentsResource>> {
         return CommonResourceService.defaultResponse(
-            this.serverApi
-                .get(this.resourceType + '/shared', { params }),
+            this.serverApi.get(this.resourceType + '/shared', { params }),
             this.actions
         );
     }
 }
 
 export enum GroupContentsResourcePrefix {
-    COLLECTION = "collections",
-    PROJECT = "groups",
-    PROCESS = "container_requests",
-    WORKFLOW = "workflows"
+    COLLECTION = 'collections',
+    PROJECT = 'groups',
+    PROCESS = 'container_requests',
+    WORKFLOW = 'workflows',
 }