Merge branch 'master' into 13833-edit-project
[arvados.git] / src / common / webdav.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 export class WebDAV {
6
7     defaults: WebDAVDefaults = {
8         baseURL: '',
9         headers: {},
10     };
11
12     constructor(config?: Partial<WebDAVDefaults>, private createRequest = () => new XMLHttpRequest()) {
13         if (config) {
14             this.defaults = { ...this.defaults, ...config };
15         }
16     }
17
18     propfind = (url: string, config: WebDAVRequestConfig = {}) =>
19         this.request({
20             ...config, url,
21             method: 'PROPFIND'
22         })
23
24     put = (url: string, data?: any, config: WebDAVRequestConfig = {}) =>
25         this.request({
26             ...config, url,
27             method: 'PUT',
28             data,
29         })
30
31     copy = (url: string, destination: string, config: WebDAVRequestConfig = {}) =>
32         this.request({
33             ...config, url,
34             method: 'COPY',
35             headers: { ...config.headers, Destination: this.defaults.baseURL + destination }
36         })
37
38     move = (url: string, destination: string, config: WebDAVRequestConfig = {}) =>
39         this.request({
40             ...config, url,
41             method: 'MOVE',
42             headers: { ...config.headers, Destination: this.defaults.baseURL + destination }
43         })
44
45     delete = (url: string, config: WebDAVRequestConfig = {}) =>
46         this.request({
47             ...config, url,
48             method: 'DELETE'
49         })
50
51     private request = (config: RequestConfig) => {
52         return new Promise<XMLHttpRequest>((resolve, reject) => {
53             const r = this.createRequest();
54             r.open(config.method, this.defaults.baseURL + config.url);
55
56             const headers = { ...this.defaults.headers, ...config.headers };
57             Object
58                 .keys(headers)
59                 .forEach(key => r.setRequestHeader(key, headers[key]));
60
61             if (config.onProgress) {
62                 r.addEventListener('progress', config.onProgress);
63             }
64
65             r.addEventListener('load', () => resolve(r));
66             r.addEventListener('error', () => reject(r));
67
68             r.send(config.data);
69         });
70     }
71 }
72 export interface WebDAVRequestConfig {
73     headers?: {
74         [key: string]: string;
75     };
76     onProgress?: (event: ProgressEvent) => void;
77 }
78
79 interface WebDAVDefaults {
80     baseURL: string;
81     headers: { [key: string]: string };
82 }
83
84 interface RequestConfig {
85     method: string;
86     url: string;
87     headers?: { [key: string]: string };
88     data?: any;
89     onProgress?: (event: ProgressEvent) => void;
90 }