X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b6ac7fe88d347582d39fffa002e300af222c578f..ddfb91e9eee0902fba8b972e2724b2eb4707654a:/src/services/common-service/common-service.ts diff --git a/src/services/common-service/common-service.ts b/src/services/common-service/common-service.ts index 82777342b3..8e9fe63170 100644 --- a/src/services/common-service/common-service.ts +++ b/src/services/common-service/common-service.ts @@ -3,10 +3,11 @@ // SPDX-License-Identifier: AGPL-3.0 import { camelCase, isPlainObject, isArray, snakeCase } from "lodash"; -import { AxiosInstance, AxiosPromise } from "axios"; +import { AxiosInstance, AxiosPromise, AxiosRequestConfig } from "axios"; import uuid from "uuid/v4"; import { ApiActions } from "services/api/api-actions"; import QueryString from "query-string"; +import { Session } from "models/session"; interface Errors { status: number; @@ -68,7 +69,7 @@ export class CommonService { } } - private validateUuid(uuid: string) { + protected validateUuid(uuid: string) { if (uuid === "") { throw new Error('UUID cannot be empty string'); } @@ -86,11 +87,13 @@ export class CommonService { return mapKeys ? CommonService.mapResponseKeys(response) : response.data; }) .catch(({ response }) => { - actions.progressFn(reqId, false); - const errors = CommonService.mapResponseKeys(response) as Errors; - errors.status = response.status; - actions.errorFn(reqId, errors, showErrors); - throw errors; + if (response) { + actions.progressFn(reqId, false); + const errors = CommonService.mapResponseKeys(response) as Errors; + errors.status = response.status; + actions.errorFn(reqId, errors, showErrors); + throw errors; + } }); } @@ -104,42 +107,63 @@ export class CommonService { ); } - delete(uuid: string): Promise { + delete(uuid: string, showErrors?: boolean): Promise { this.validateUuid(uuid); return CommonService.defaultResponse( this.serverApi .delete(`/${this.resourceType}/${uuid}`), - this.actions + this.actions, + true, // mapKeys + showErrors ); } - get(uuid: string, showErrors?: boolean) { + get(uuid: string, showErrors?: boolean, select?: string[], session?: Session) { this.validateUuid(uuid); + + const cfg: AxiosRequestConfig = { + params: { + select: select + ? `[${select.map(snakeCase).map(s => `"${s}"`).join(',')}]` + : undefined + } + }; + if (session) { + cfg.baseURL = session.baseUrl; + cfg.headers = { 'Authorization': 'Bearer ' + session.token }; + } + return CommonService.defaultResponse( this.serverApi - .get(`/${this.resourceType}/${uuid}`), + .get(`/${this.resourceType}/${uuid}`, cfg), this.actions, true, // mapKeys showErrors ); } - list(args: ListArguments = {}): Promise> { - const { filters, order, ...other } = args; + list(args: ListArguments = {}, showErrors?: boolean): Promise> { + const { filters, select, ...other } = args; const params = { ...CommonService.mapKeys(snakeCase)(other), filters: filters ? `[${filters}]` : undefined, - order: order ? order : undefined + select: select + ? `[${select.map(snakeCase).map(s => `"${s}"`).join(', ')}]` + : undefined }; if (QueryString.stringify(params).length <= 1500) { return CommonService.defaultResponse( this.serverApi.get(`/${this.resourceType}`, { params }), - this.actions + this.actions, + true, + showErrors ); } else { // Using the POST special case to avoid URI length 414 errors. - const formData = new FormData(); + // We must use urlencoded post body since api doesn't support form data + // const formData = new FormData(); + const formData = new URLSearchParams(); formData.append("_method", "GET"); Object.keys(params).forEach(key => { if (params[key] !== undefined) { @@ -147,22 +171,22 @@ export class CommonService { } }); return CommonService.defaultResponse( - this.serverApi.post(`/${this.resourceType}`, formData, { - params: { - _method: 'GET' - } - }), - this.actions + this.serverApi.post(`/${this.resourceType}`, formData, {}), + this.actions, + true, + showErrors ); } } - update(uuid: string, data: Partial) { + update(uuid: string, data: Partial, showErrors?: boolean) { this.validateUuid(uuid); return CommonService.defaultResponse( this.serverApi .put(`/${this.resourceType}/${uuid}`, data && CommonService.mapKeys(snakeCase)(data)), - this.actions + this.actions, + undefined, // mapKeys + showErrors ); } }