@deltares/fews-web-oc-utils 0.1.8 → 0.1.10
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 +12 -15
- 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/piRestService.d.ts +2 -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 +12 -16
- 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:()=>o,RequestOptions:()=>s});class r{async parse(e){return await e.json()}}class s{_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}}class o{webserviceUrl;_oauth2Token=void 0;set oauth2Token(e){this._oauth2Token=e}constructor(e){this.webserviceUrl=e}async getDataWithParser(e,t,r){const s=t.relativeUrl?this.webserviceUrl+e:e,o={method:"GET"};void 0!==this._oauth2Token&&(o.headers={Authorization:"Bearer "+this._oauth2Token});const a=await fetch(s,o);return await this.processResponse({},a,s,r)}async getData(e){const t=new s;return t.relativeUrl=!1,this.getDataWithParser(e,t,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)}}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,5 @@
|
|
|
1
|
+
import { DefaultParser } from "../parser";
|
|
2
|
+
import { RequestOptions } from "./requestOptions";
|
|
1
3
|
export class PiRestService {
|
|
2
4
|
webserviceUrl;
|
|
3
5
|
_oauth2Token = undefined;
|
|
@@ -7,35 +9,30 @@ export class PiRestService {
|
|
|
7
9
|
constructor(webserviceUrl) {
|
|
8
10
|
this.webserviceUrl = webserviceUrl;
|
|
9
11
|
}
|
|
10
|
-
async getDataWithParser(url, parser) {
|
|
12
|
+
async getDataWithParser(url, requestOption, parser) {
|
|
13
|
+
const requestUrl = requestOption.relativeUrl ? this.webserviceUrl + url : url;
|
|
11
14
|
const dataRequestResult = {};
|
|
12
15
|
const requestParameters = {};
|
|
13
16
|
requestParameters.method = "GET";
|
|
14
17
|
if (this._oauth2Token !== undefined) {
|
|
15
18
|
requestParameters.headers = { "Authorization": "Bearer " + this._oauth2Token };
|
|
16
19
|
}
|
|
17
|
-
const res = await fetch(
|
|
18
|
-
|
|
19
|
-
return dataRequestResult;
|
|
20
|
+
const res = await fetch(requestUrl, requestParameters);
|
|
21
|
+
return await this.processResponse(dataRequestResult, res, requestUrl, parser);
|
|
20
22
|
}
|
|
21
23
|
async getData(url) {
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
|
|
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);
|
|
24
|
+
const requestOption = new RequestOptions();
|
|
25
|
+
requestOption.relativeUrl = false;
|
|
26
|
+
return this.getDataWithParser(url, requestOption, new DefaultParser());
|
|
30
27
|
}
|
|
31
|
-
async processResponse(dataRequestResult, res, url) {
|
|
28
|
+
async processResponse(dataRequestResult, res, url, parser) {
|
|
32
29
|
dataRequestResult.responseCode = res.status;
|
|
33
30
|
if (res.status != 200) {
|
|
34
31
|
dataRequestResult.errorMessage = res.statusText;
|
|
35
32
|
return dataRequestResult;
|
|
36
33
|
}
|
|
37
34
|
try {
|
|
38
|
-
dataRequestResult.data = await
|
|
35
|
+
dataRequestResult.data = await parser.parse(res);
|
|
39
36
|
}
|
|
40
37
|
catch (e) {
|
|
41
38
|
e.message += `\n When loading ${url}.`;
|
|
@@ -50,7 +47,7 @@ export class PiRestService {
|
|
|
50
47
|
requestInit.headers = { ...authorizationHeader, ...requestInit.headers };
|
|
51
48
|
}
|
|
52
49
|
const res = await fetch(url, requestInit);
|
|
53
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
50
|
+
return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
|
|
54
51
|
}
|
|
55
52
|
}
|
|
56
53
|
//# 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;AACxC,OAAO,EAAC,cAAc,EAAC,MAAM,kBAAkB,CAAC;AAEhD,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,aAA6B,EAAE,MAAyB;QACnG,MAAM,UAAU,GAAG,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAC9E,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,UAAU,EAAE,iBAAiB,CAAC,CAAC;QACvD,OAAO,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE,GAAG,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAClF,CAAC;IAEM,KAAK,CAAC,OAAO,CAAI,GAAW;QAC/B,MAAM,aAAa,GAAG,IAAI,cAAc,EAAE,CAAA;QAC1C,aAAa,CAAC,WAAW,GAAG,KAAK,CAAA;QACjC,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,aAAa,EAAE,IAAI,aAAa,EAAE,CAAC,CAAC;IAC3E,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"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import DataRequestResult from "./dataRequestResult";
|
|
2
2
|
import { ResponseParser } from "../parser/responseParser";
|
|
3
|
+
import { RequestOptions } from "./requestOptions";
|
|
3
4
|
export declare class PiRestService {
|
|
4
5
|
private readonly webserviceUrl;
|
|
5
6
|
private _oauth2Token;
|
|
6
7
|
set oauth2Token(value: string);
|
|
7
8
|
constructor(webserviceUrl: string);
|
|
8
|
-
getDataWithParser<T>(url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>>;
|
|
9
|
+
getDataWithParser<T>(url: string, requestOption: RequestOptions, parser: ResponseParser<T>): Promise<DataRequestResult<T>>;
|
|
9
10
|
getData<T>(url: string): Promise<DataRequestResult<T>>;
|
|
10
11
|
private processResponse;
|
|
11
12
|
getDataWithRequestInit<T>(url: string, requestInit: RequestInit): Promise<DataRequestResult<T>>;
|
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,7 @@
|
|
|
1
1
|
import DataRequestResult from "./dataRequestResult";
|
|
2
2
|
import {ResponseParser} from "../parser/responseParser";
|
|
3
|
+
import {DefaultParser} from "../parser";
|
|
4
|
+
import {RequestOptions} from "./requestOptions";
|
|
3
5
|
|
|
4
6
|
export class PiRestService {
|
|
5
7
|
private readonly webserviceUrl: string;
|
|
@@ -13,38 +15,32 @@ export class PiRestService {
|
|
|
13
15
|
this.webserviceUrl = webserviceUrl;
|
|
14
16
|
}
|
|
15
17
|
|
|
16
|
-
public async getDataWithParser<T>(url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {
|
|
18
|
+
public async getDataWithParser<T>(url: string, requestOption: RequestOptions, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {
|
|
19
|
+
const requestUrl = requestOption.relativeUrl ? this.webserviceUrl + url : url;
|
|
17
20
|
const dataRequestResult = {} as DataRequestResult<T>;
|
|
18
21
|
const requestParameters = {} as RequestInit;
|
|
19
22
|
requestParameters.method = "GET";
|
|
20
23
|
if (this._oauth2Token !== undefined) {
|
|
21
24
|
requestParameters.headers = {"Authorization": "Bearer " + this._oauth2Token}
|
|
22
25
|
}
|
|
23
|
-
const res = await fetch(
|
|
24
|
-
|
|
25
|
-
return dataRequestResult;
|
|
26
|
+
const res = await fetch(requestUrl, requestParameters);
|
|
27
|
+
return await this.processResponse(dataRequestResult, res, requestUrl, parser);
|
|
26
28
|
}
|
|
27
29
|
|
|
28
30
|
public async getData<T>(url: string): Promise<DataRequestResult<T>> {
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
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);
|
|
31
|
+
const requestOption = new RequestOptions()
|
|
32
|
+
requestOption.relativeUrl = false
|
|
33
|
+
return this.getDataWithParser(url, requestOption, new DefaultParser());
|
|
38
34
|
}
|
|
39
35
|
|
|
40
|
-
private async processResponse<T>(dataRequestResult: DataRequestResult<T>, res: Response, url: string): Promise<DataRequestResult<T>> {
|
|
36
|
+
private async processResponse<T>(dataRequestResult: DataRequestResult<T>, res: Response, url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {
|
|
41
37
|
dataRequestResult.responseCode = res.status;
|
|
42
38
|
if (res.status != 200) {
|
|
43
39
|
dataRequestResult.errorMessage = res.statusText;
|
|
44
40
|
return dataRequestResult;
|
|
45
41
|
}
|
|
46
42
|
try {
|
|
47
|
-
dataRequestResult.data = await
|
|
43
|
+
dataRequestResult.data = await parser.parse(res);
|
|
48
44
|
} catch (e: any) {
|
|
49
45
|
e.message += `\n When loading ${url}.`
|
|
50
46
|
throw e;
|
|
@@ -59,6 +55,6 @@ export class PiRestService {
|
|
|
59
55
|
requestInit.headers = {...authorizationHeader, ...requestInit.headers};
|
|
60
56
|
}
|
|
61
57
|
const res = await fetch(url, requestInit);
|
|
62
|
-
return await this.processResponse(dataRequestResult, res, url);
|
|
58
|
+
return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
|
|
63
59
|
}
|
|
64
60
|
}
|
|
@@ -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
|
}
|