projects
/
arvados.git
/ blobdiff
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
merge master
[arvados.git]
/
src
/
services
/
groups-service
/
groups-service.ts
diff --git
a/src/services/groups-service/groups-service.ts
b/src/services/groups-service/groups-service.ts
index f230c70fa0bdd94ca3867f283fd2e7babe9303e2..a0f27a4abbe27f26939e4d5be7c368f580eb9b32 100644
(file)
--- a/
src/services/groups-service/groups-service.ts
+++ b/
src/services/groups-service/groups-service.ts
@@
-3,23
+3,16
@@
// SPDX-License-Identifier: AGPL-3.0
import * as _ from "lodash";
// SPDX-License-Identifier: AGPL-3.0
import * as _ from "lodash";
-import
CommonResourceService, { Resour
ce, ListResults } from "../../common/api/common-resource-service";
-import
FilterBuilder
from "../../common/api/filter-builder";
-import
OrderBuilder
from "../../common/api/order-builder";
+import
{ CommonResourceServi
ce, ListResults } from "../../common/api/common-resource-service";
+import
{ FilterBuilder }
from "../../common/api/filter-builder";
+import
{ OrderBuilder }
from "../../common/api/order-builder";
import { AxiosInstance } from "axios";
import { AxiosInstance } from "axios";
+import { GroupResource } from "../../models/group";
+import { CollectionResource } from "../../models/collection";
+import { ProjectResource } from "../../models/project";
+import { ProcessResource } from "../../models/process";
-interface GroupResource extends Resource {
- name: string;
- groupClass: string;
- description: string;
- properties: string;
- writeableBy: string[];
- trashAt: string;
- deleteAt: string;
- isTrashed: boolean;
-}
-
-interface ContensArguments {
+export interface ContentsArguments {
limit?: number;
offset?: number;
order?: OrderBuilder;
limit?: number;
offset?: number;
order?: OrderBuilder;
@@
-27,18
+20,23
@@
interface ContensArguments {
recursive?: boolean;
}
recursive?: boolean;
}
-export default class GroupsService extends CommonResourceService<GroupResource> {
+export type GroupContentsResource =
+ CollectionResource |
+ ProjectResource |
+ ProcessResource;
+
+export class GroupsService<T extends GroupResource = GroupResource> extends CommonResourceService<T> {
constructor(serverApi: AxiosInstance) {
super(serverApi, "groups");
}
constructor(serverApi: AxiosInstance) {
super(serverApi, "groups");
}
- contents
(uuid: string, args: ContensArguments = {}): Promise<ListResults<
Resource>> {
+ contents
(uuid: string, args: ContentsArguments = {}): Promise<ListResults<GroupContents
Resource>> {
const { filters, order, ...other } = args;
const params = {
...other,
const { filters, order, ...other } = args;
const params = {
...other,
- filters: filters ? filters.
get
() : undefined,
- order: order ? order.get() : undefined
+ filters: filters ? filters.
serialize
() : undefined,
+ order: order ? order.get
Order
() : undefined
};
return this.serverApi
.get(this.resourceType + `${uuid}/contents/`, {
};
return this.serverApi
.get(this.resourceType + `${uuid}/contents/`, {
@@
-46,4
+44,10
@@
export default class GroupsService extends CommonResourceService<GroupResource>
})
.then(CommonResourceService.mapResponseKeys);
}
})
.then(CommonResourceService.mapResponseKeys);
}
-}
\ No newline at end of file
+}
+
+export enum GroupContentsResourcePrefix {
+ COLLECTION = "collections",
+ PROJECT = "groups",
+ PROCESS = "container_requests"
+}