refs #14186 Merge branch 'origin/14186-progress-indicator-store'
[arvados-workbench2.git] / src / services / services.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import Axios from "axios";
6 import { AuthService } from "./auth-service/auth-service";
7 import { GroupsService } from "./groups-service/groups-service";
8 import { ProjectService } from "./project-service/project-service";
9 import { LinkService } from "./link-service/link-service";
10 import { FavoriteService } from "./favorite-service/favorite-service";
11 import { CollectionService } from "./collection-service/collection-service";
12 import { TagService } from "./tag-service/tag-service";
13 import { CollectionFilesService } from "./collection-files-service/collection-files-service";
14 import { KeepService } from "./keep-service/keep-service";
15 import { WebDAV } from "~/common/webdav";
16 import { Config } from "~/common/config";
17 import { UserService } from './user-service/user-service';
18 import { AncestorService } from "~/services/ancestors-service/ancestors-service";
19 import { ResourceKind } from "~/models/resource";
20 import { ContainerRequestService } from './container-request-service/container-request-service';
21 import { ContainerService } from './container-service/container-service';
22 import { LogService } from './log-service/log-service';
23 import { ApiActions } from "~/services/api/api-actions";
24
25 export type ServiceRepository = ReturnType<typeof createServices>;
26
27 export const createServices = (config: Config, actions: ApiActions) => {
28     const apiClient = Axios.create();
29     apiClient.defaults.baseURL = config.baseUrl;
30
31     const webdavClient = new WebDAV();
32     webdavClient.defaults.baseURL = config.keepWebServiceUrl;
33
34     const containerRequestService = new ContainerRequestService(apiClient, actions);
35     const containerService = new ContainerService(apiClient, actions);
36     const groupsService = new GroupsService(apiClient, actions);
37     const keepService = new KeepService(apiClient, actions);
38     const linkService = new LinkService(apiClient, actions);
39     const logService = new LogService(apiClient, actions);
40     const projectService = new ProjectService(apiClient, actions);
41     const userService = new UserService(apiClient, actions);
42
43     const ancestorsService = new AncestorService(groupsService, userService);
44     const authService = new AuthService(apiClient, config.rootUrl, actions);
45     const collectionService = new CollectionService(apiClient, webdavClient, authService, actions);
46     const collectionFilesService = new CollectionFilesService(collectionService);
47     const favoriteService = new FavoriteService(linkService, groupsService);
48     const tagService = new TagService(linkService);
49
50     return {
51         ancestorsService,
52         apiClient,
53         authService,
54         collectionFilesService,
55         collectionService,
56         containerRequestService,
57         containerService,
58         favoriteService,
59         groupsService,
60         keepService,
61         linkService,
62         logService,
63         projectService,
64         tagService,
65         userService,
66         webdavClient,
67     };
68 };
69
70 export const getResourceService = (kind?: ResourceKind) => (serviceRepository: ServiceRepository) => {
71     switch (kind) {
72         case ResourceKind.USER:
73             return serviceRepository.userService;
74         case ResourceKind.GROUP:
75             return serviceRepository.groupsService;
76         case ResourceKind.COLLECTION:
77             return serviceRepository.collectionService;
78         default:
79             return undefined;
80     }
81 };