@deltares/fews-web-oc-utils 0.1.8 → 0.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/fews-web-oc-utils.umd.js +1 -1
- package/dist/lib/parser/defaultParser.js +1 -2
- package/dist/lib/parser/defaultParser.js.map +1 -1
- package/dist/lib/restservice/piRestService.js +6 -13
- package/dist/lib/restservice/piRestService.js.map +1 -1
- package/dist/lib/restservice/requestOptions.js +16 -1
- package/dist/lib/restservice/requestOptions.js.map +1 -1
- package/dist/types/restservice/requestOptions.d.ts +7 -2
- package/package.json +1 -1
- package/src/parser/defaultParser.ts +2 -3
- package/src/restservice/piRestService.ts +6 -14
- package/src/restservice/requestOptions.ts +21 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports["fews-web-oc-utils"]=t():e["fews-web-oc-utils"]=t()}(self,(function(){return(()=>{"use strict";var e={d:(t,
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports["fews-web-oc-utils"]=t():e["fews-web-oc-utils"]=t()}(self,(function(){return(()=>{"use strict";var e={d:(t,r)=>{for(var s in r)e.o(r,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:r[s]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r:e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{DefaultParser:()=>r,PiRestService:()=>s,RequestOptions:()=>o});class r{async parse(e){return await e.json()}}class s{webserviceUrl;_oauth2Token=void 0;set oauth2Token(e){this._oauth2Token=e}constructor(e){this.webserviceUrl=e}async getDataWithParser(e,t){const r={method:"GET"};void 0!==this._oauth2Token&&(r.headers={Authorization:"Bearer "+this._oauth2Token});const s=await fetch(e,r);return await this.processResponse({},s,e,t)}async getData(e){return this.getDataWithParser(e,new r)}async processResponse(e,t,r,s){if(e.responseCode=t.status,200!=t.status)return e.errorMessage=t.statusText,e;try{e.data=await s.parse(t)}catch(e){throw e.message+=`\n When loading ${r}.`,e}return e}async getDataWithRequestInit(e,t){if(void 0!==this._oauth2Token){const e={Authorization:"Bearer "+this._oauth2Token};t.headers={...e,...t.headers}}const s=await fetch(e,t);return await this.processResponse({},s,e,new r)}}class o{_mode="cors";_relativeUrl=!0;get relativeUrl(){return this._relativeUrl}set relativeUrl(e){this._relativeUrl=e}get mode(){return this._mode}set mode(e){this._mode=e}}return t})()}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"defaultParser.js","sourceRoot":"","sources":["../../../src/parser/defaultParser.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,aAAa;IACtB,KAAK,CAAC,KAAK,CAAC,QAAkB;QAC1B,
|
|
1
|
+
{"version":3,"file":"defaultParser.js","sourceRoot":"","sources":["../../../src/parser/defaultParser.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,aAAa;IACtB,KAAK,CAAC,KAAK,CAAC,QAAkB;QAC1B,OAAO,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;IAChC,CAAC;CACJ"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { DefaultParser } from "../parser";
|
|
1
2
|
export class PiRestService {
|
|
2
3
|
webserviceUrl;
|
|
3
4
|
_oauth2Token = undefined;
|
|
@@ -15,27 +16,19 @@ export class PiRestService {
|
|
|
15
16
|
requestParameters.headers = { "Authorization": "Bearer " + this._oauth2Token };
|
|
16
17
|
}
|
|
17
18
|
const res = await fetch(url, requestParameters);
|
|
18
|
-
|
|
19
|
-
return dataRequestResult;
|
|
19
|
+
return await this.processResponse(dataRequestResult, res, url, parser);
|
|
20
20
|
}
|
|
21
21
|
async getData(url) {
|
|
22
|
-
|
|
23
|
-
const requestParameters = {};
|
|
24
|
-
requestParameters.method = "GET";
|
|
25
|
-
if (this._oauth2Token !== undefined) {
|
|
26
|
-
requestParameters.headers = { "Authorization": "Bearer " + this._oauth2Token };
|
|
27
|
-
}
|
|
28
|
-
const res = await fetch(url, requestParameters);
|
|
29
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
22
|
+
return this.getDataWithParser(url, new DefaultParser());
|
|
30
23
|
}
|
|
31
|
-
async processResponse(dataRequestResult, res, url) {
|
|
24
|
+
async processResponse(dataRequestResult, res, url, parser) {
|
|
32
25
|
dataRequestResult.responseCode = res.status;
|
|
33
26
|
if (res.status != 200) {
|
|
34
27
|
dataRequestResult.errorMessage = res.statusText;
|
|
35
28
|
return dataRequestResult;
|
|
36
29
|
}
|
|
37
30
|
try {
|
|
38
|
-
dataRequestResult.data = await
|
|
31
|
+
dataRequestResult.data = await parser.parse(res);
|
|
39
32
|
}
|
|
40
33
|
catch (e) {
|
|
41
34
|
e.message += `\n When loading ${url}.`;
|
|
@@ -50,7 +43,7 @@ export class PiRestService {
|
|
|
50
43
|
requestInit.headers = { ...authorizationHeader, ...requestInit.headers };
|
|
51
44
|
}
|
|
52
45
|
const res = await fetch(url, requestInit);
|
|
53
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
46
|
+
return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
|
|
54
47
|
}
|
|
55
48
|
}
|
|
56
49
|
//# sourceMappingURL=piRestService.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"piRestService.js","sourceRoot":"","sources":["../../../src/restservice/piRestService.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"piRestService.js","sourceRoot":"","sources":["../../../src/restservice/piRestService.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,aAAa,EAAC,MAAM,WAAW,CAAC;AAExC,MAAM,OAAO,aAAa;IACL,aAAa,CAAS;IAC/B,YAAY,GAAuB,SAAS,CAAC;IAErD,IAAI,WAAW,CAAC,KAAa;QACzB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,YAAY,aAAqB;QAC7B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,iBAAiB,CAAI,GAAW,EAAE,MAAyB;QACpE,MAAM,iBAAiB,GAAG,EAA0B,CAAC;QACrD,MAAM,iBAAiB,GAAG,EAAiB,CAAC;QAC5C,iBAAiB,CAAC,MAAM,GAAG,KAAK,CAAC;QACjC,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;YACjC,iBAAiB,CAAC,OAAO,GAAG,EAAC,eAAe,EAAE,SAAS,GAAG,IAAI,CAAC,YAAY,EAAC,CAAA;SAC/E;QACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,EAAC,iBAAiB,CAAC,CAAC;QAC/C,OAAO,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAC3E,CAAC;IAEM,KAAK,CAAC,OAAO,CAAI,GAAW;QAC/B,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,IAAI,aAAa,EAAE,CAAC,CAAC;IAC5D,CAAC;IAEO,KAAK,CAAC,eAAe,CAAI,iBAAuC,EAAE,GAAa,EAAE,GAAW,EAAE,MAAyB;QAC3H,iBAAiB,CAAC,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC;QAC5C,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,EAAE;YACnB,iBAAiB,CAAC,YAAY,GAAG,GAAG,CAAC,UAAU,CAAC;YAChD,OAAO,iBAAiB,CAAC;SAC5B;QACD,IAAI;YACA,iBAAiB,CAAC,IAAI,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SACpD;QAAC,OAAO,CAAM,EAAE;YACb,CAAC,CAAC,OAAO,IAAI,mBAAmB,GAAG,GAAG,CAAA;YACtC,MAAM,CAAC,CAAC;SACX;QACD,OAAO,iBAAiB,CAAC;IAC7B,CAAC;IAEM,KAAK,CAAC,sBAAsB,CAAI,GAAW,EAAE,WAAwB;QACxE,MAAM,iBAAiB,GAAG,EAA0B,CAAC;QACrD,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;YACjC,MAAM,mBAAmB,GAAG,EAAC,eAAe,EAAE,SAAS,GAAG,IAAI,CAAC,YAAY,EAAC,CAAC;YAC7E,WAAW,CAAC,OAAO,GAAG,EAAC,GAAG,mBAAmB,EAAE,GAAG,WAAW,CAAC,OAAO,EAAC,CAAC;SAC1E;QACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QAC1C,OAAO,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,aAAa,EAAE,CAAC,CAAC;IACxF,CAAC;CACJ"}
|
|
@@ -1,2 +1,17 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export class RequestOptions {
|
|
2
|
+
_mode = "cors";
|
|
3
|
+
_relativeUrl = true;
|
|
4
|
+
get relativeUrl() {
|
|
5
|
+
return this._relativeUrl;
|
|
6
|
+
}
|
|
7
|
+
set relativeUrl(value) {
|
|
8
|
+
this._relativeUrl = value;
|
|
9
|
+
}
|
|
10
|
+
get mode() {
|
|
11
|
+
return this._mode;
|
|
12
|
+
}
|
|
13
|
+
set mode(value) {
|
|
14
|
+
this._mode = value;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
2
17
|
//# sourceMappingURL=requestOptions.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"requestOptions.js","sourceRoot":"","sources":["../../../src/restservice/requestOptions.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"requestOptions.js","sourceRoot":"","sources":["../../../src/restservice/requestOptions.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,cAAc;IACf,KAAK,GAAG,MAAM,CAAC;IACf,YAAY,GAAG,IAAI,CAAC;IAG5B,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAI,WAAW,CAAC,KAAK;QACjB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAED,IAAI,IAAI,CAAC,KAAa;QAClB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;CAEJ"}
|
package/package.json
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {ResponseParser} from "../parser/responseParser";
|
|
2
2
|
|
|
3
3
|
export class DefaultParser<T> implements ResponseParser<T> {
|
|
4
4
|
async parse(response: Response): Promise<T> {
|
|
5
|
-
|
|
6
|
-
return result
|
|
5
|
+
return await response.json()
|
|
7
6
|
}
|
|
8
7
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import DataRequestResult from "./dataRequestResult";
|
|
2
2
|
import {ResponseParser} from "../parser/responseParser";
|
|
3
|
+
import {DefaultParser} from "../parser";
|
|
3
4
|
|
|
4
5
|
export class PiRestService {
|
|
5
6
|
private readonly webserviceUrl: string;
|
|
@@ -21,30 +22,21 @@ export class PiRestService {
|
|
|
21
22
|
requestParameters.headers = {"Authorization": "Bearer " + this._oauth2Token}
|
|
22
23
|
}
|
|
23
24
|
const res = await fetch(url,requestParameters);
|
|
24
|
-
|
|
25
|
-
return dataRequestResult;
|
|
25
|
+
return await this.processResponse(dataRequestResult, res, url, parser);
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
public async getData<T>(url: string): Promise<DataRequestResult<T>> {
|
|
29
|
-
|
|
30
|
-
const requestParameters = {} as RequestInit;
|
|
31
|
-
requestParameters.method = "GET";
|
|
32
|
-
if (this._oauth2Token !== undefined) {
|
|
33
|
-
requestParameters.headers = {"Authorization": "Bearer " + this._oauth2Token}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
const res = await fetch(url,requestParameters);
|
|
37
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
29
|
+
return this.getDataWithParser(url, new DefaultParser());
|
|
38
30
|
}
|
|
39
31
|
|
|
40
|
-
private async processResponse<T>(dataRequestResult: DataRequestResult<T>, res: Response, url: string): Promise<DataRequestResult<T>> {
|
|
32
|
+
private async processResponse<T>(dataRequestResult: DataRequestResult<T>, res: Response, url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {
|
|
41
33
|
dataRequestResult.responseCode = res.status;
|
|
42
34
|
if (res.status != 200) {
|
|
43
35
|
dataRequestResult.errorMessage = res.statusText;
|
|
44
36
|
return dataRequestResult;
|
|
45
37
|
}
|
|
46
38
|
try {
|
|
47
|
-
dataRequestResult.data = await
|
|
39
|
+
dataRequestResult.data = await parser.parse(res);
|
|
48
40
|
} catch (e: any) {
|
|
49
41
|
e.message += `\n When loading ${url}.`
|
|
50
42
|
throw e;
|
|
@@ -59,6 +51,6 @@ export class PiRestService {
|
|
|
59
51
|
requestInit.headers = {...authorizationHeader, ...requestInit.headers};
|
|
60
52
|
}
|
|
61
53
|
const res = await fetch(url, requestInit);
|
|
62
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
54
|
+
return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
|
|
63
55
|
}
|
|
64
56
|
}
|
|
@@ -1,3 +1,22 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
1
|
+
export class RequestOptions {
|
|
2
|
+
private _mode = "cors";
|
|
3
|
+
private _relativeUrl = true;
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
get relativeUrl(): boolean {
|
|
7
|
+
return this._relativeUrl;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
set relativeUrl(value) {
|
|
11
|
+
this._relativeUrl = value;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
get mode(): string {
|
|
15
|
+
return this._mode;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
set mode(value: string) {
|
|
19
|
+
this._mode = value;
|
|
20
|
+
}
|
|
21
|
+
|
|
3
22
|
}
|