@deltares/fews-web-oc-utils 0.1.7 → 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.
@@ -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,o)=>{for(var s in o)e.o(o,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:o[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,{PiRestService:()=>o});class o{webserviceUrl;_oauth2Token=void 0;set oauth2Token(e){this._oauth2Token=e}constructor(e){this.webserviceUrl=e}async getData(e){const t={method:"GET"};void 0!==this._oauth2Token&&(t.headers={Authorization:"Bearer "+this._oauth2Token});const o=await fetch(e,t);return await this.processResponse({},o,e)}async processResponse(e,t,o){if(e.responseCode=t.status,200!=t.status)return e.errorMessage=t.statusText,e;try{e.data=await t.json()}catch(e){throw e.message+=`\n When loading ${o}.`,e}return e}async getDataWithRequestInit(e,t){if(void 0!==this._oauth2Token){const e={Authorization:"Bearer "+this._oauth2Token};t.headers={...e,...t.headers}}const o=await fetch(e,t);return await this.processResponse({},o,e)}}return 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})()}));
package/dist/lib/index.js CHANGED
@@ -1,2 +1,3 @@
1
1
  export * from './restservice';
2
+ export * from './parser';
2
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAA;AAC7B,cAAc,UAAU,CAAA"}
@@ -0,0 +1,6 @@
1
+ export class DefaultParser {
2
+ async parse(response) {
3
+ return await response.json();
4
+ }
5
+ }
6
+ //# sourceMappingURL=defaultParser.js.map
@@ -0,0 +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,OAAO,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;IAChC,CAAC;CACJ"}
@@ -0,0 +1,3 @@
1
+ export * from './defaultParser';
2
+ export * from './responseParser';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/parser/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,kBAAkB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=responseParser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"responseParser.js","sourceRoot":"","sources":["../../../src/parser/responseParser.ts"],"names":[],"mappings":""}
@@ -1,3 +1,4 @@
1
+ import { DefaultParser } from "../parser";
1
2
  export class PiRestService {
2
3
  webserviceUrl;
3
4
  _oauth2Token = undefined;
@@ -7,7 +8,7 @@ export class PiRestService {
7
8
  constructor(webserviceUrl) {
8
9
  this.webserviceUrl = webserviceUrl;
9
10
  }
10
- async getData(url) {
11
+ async getDataWithParser(url, parser) {
11
12
  const dataRequestResult = {};
12
13
  const requestParameters = {};
13
14
  requestParameters.method = "GET";
@@ -15,16 +16,19 @@ export class PiRestService {
15
16
  requestParameters.headers = { "Authorization": "Bearer " + this._oauth2Token };
16
17
  }
17
18
  const res = await fetch(url, requestParameters);
18
- return await this.processResponse(dataRequestResult, res, url);
19
+ return await this.processResponse(dataRequestResult, res, url, parser);
20
+ }
21
+ async getData(url) {
22
+ return this.getDataWithParser(url, new DefaultParser());
19
23
  }
20
- async processResponse(dataRequestResult, res, url) {
24
+ async processResponse(dataRequestResult, res, url, parser) {
21
25
  dataRequestResult.responseCode = res.status;
22
26
  if (res.status != 200) {
23
27
  dataRequestResult.errorMessage = res.statusText;
24
28
  return dataRequestResult;
25
29
  }
26
30
  try {
27
- dataRequestResult.data = await res.json();
31
+ dataRequestResult.data = await parser.parse(res);
28
32
  }
29
33
  catch (e) {
30
34
  e.message += `\n When loading ${url}.`;
@@ -39,7 +43,7 @@ export class PiRestService {
39
43
  requestInit.headers = { ...authorizationHeader, ...requestInit.headers };
40
44
  }
41
45
  const res = await fetch(url, requestInit);
42
- return await this.processResponse(dataRequestResult, res, url);
46
+ return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
43
47
  }
44
48
  }
45
49
  //# sourceMappingURL=piRestService.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"piRestService.js","sourceRoot":"","sources":["../../../src/restservice/piRestService.ts"],"names":[],"mappings":"AAEA,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,OAAO,CAAI,GAAW;QAC/B,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;QAED,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,EAAC,iBAAiB,CAAC,CAAC;QAC/C,OAAO,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEO,KAAK,CAAC,eAAe,CAAI,iBAAuC,EAAE,GAAa,EAAE,GAAW;QAChG,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,GAAG,CAAC,IAAI,EAAE,CAAC;SAC7C;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,CAAC,CAAC;IACnE,CAAC;CACJ"}
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"}
@@ -1 +1,2 @@
1
1
  export * from './restservice';
2
+ export * from './parser';
@@ -0,0 +1,4 @@
1
+ import { ResponseParser } from "../parser/responseParser";
2
+ export declare class DefaultParser<T> implements ResponseParser<T> {
3
+ parse(response: Response): Promise<T>;
4
+ }
@@ -0,0 +1,2 @@
1
+ export * from './defaultParser';
2
+ export * from './responseParser';
@@ -0,0 +1,3 @@
1
+ export interface ResponseParser<T> {
2
+ parse(response: Response): Promise<T>;
3
+ }
@@ -1,9 +1,11 @@
1
1
  import DataRequestResult from "./dataRequestResult";
2
+ import { ResponseParser } from "../parser/responseParser";
2
3
  export declare class PiRestService {
3
4
  private readonly webserviceUrl;
4
5
  private _oauth2Token;
5
6
  set oauth2Token(value: string);
6
7
  constructor(webserviceUrl: string);
8
+ getDataWithParser<T>(url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>>;
7
9
  getData<T>(url: string): Promise<DataRequestResult<T>>;
8
10
  private processResponse;
9
11
  getDataWithRequestInit<T>(url: string, requestInit: RequestInit): Promise<DataRequestResult<T>>;
@@ -1,3 +1,8 @@
1
- export default interface RequestOptions {
2
- cache: string;
1
+ export declare class RequestOptions {
2
+ private _mode;
3
+ private _relativeUrl;
4
+ get relativeUrl(): boolean;
5
+ set relativeUrl(value: boolean);
6
+ get mode(): string;
7
+ set mode(value: string);
3
8
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deltares/fews-web-oc-utils",
3
- "version": "0.1.7",
3
+ "version": "0.1.9",
4
4
  "description": "Util Library for common Web OC functionality",
5
5
  "author": {
6
6
  "name": "Werner Kramer",
package/src/index.ts CHANGED
@@ -1 +1,2 @@
1
1
  export * from './restservice'
2
+ export * from './parser'
@@ -0,0 +1,7 @@
1
+ import {ResponseParser} from "../parser/responseParser";
2
+
3
+ export class DefaultParser<T> implements ResponseParser<T> {
4
+ async parse(response: Response): Promise<T> {
5
+ return await response.json()
6
+ }
7
+ }
@@ -0,0 +1,2 @@
1
+ export * from './defaultParser'
2
+ export * from './responseParser'
@@ -0,0 +1,3 @@
1
+ export interface ResponseParser<T> {
2
+ parse(response: Response): Promise<T>;
3
+ }
@@ -1,4 +1,6 @@
1
1
  import DataRequestResult from "./dataRequestResult";
2
+ import {ResponseParser} from "../parser/responseParser";
3
+ import {DefaultParser} from "../parser";
2
4
 
3
5
  export class PiRestService {
4
6
  private readonly webserviceUrl: string;
@@ -12,26 +14,29 @@ export class PiRestService {
12
14
  this.webserviceUrl = webserviceUrl;
13
15
  }
14
16
 
15
- public async getData<T>(url: string): Promise<DataRequestResult<T>> {
17
+ public async getDataWithParser<T>(url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {
16
18
  const dataRequestResult = {} as DataRequestResult<T>;
17
19
  const requestParameters = {} as RequestInit;
18
20
  requestParameters.method = "GET";
19
21
  if (this._oauth2Token !== undefined) {
20
22
  requestParameters.headers = {"Authorization": "Bearer " + this._oauth2Token}
21
23
  }
22
-
23
24
  const res = await fetch(url,requestParameters);
24
- return await this.processResponse(dataRequestResult, res, url);
25
+ return await this.processResponse(dataRequestResult, res, url, parser);
26
+ }
27
+
28
+ public async getData<T>(url: string): Promise<DataRequestResult<T>> {
29
+ return this.getDataWithParser(url, new DefaultParser());
25
30
  }
26
31
 
27
- 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>> {
28
33
  dataRequestResult.responseCode = res.status;
29
34
  if (res.status != 200) {
30
35
  dataRequestResult.errorMessage = res.statusText;
31
36
  return dataRequestResult;
32
37
  }
33
38
  try {
34
- dataRequestResult.data = await res.json();
39
+ dataRequestResult.data = await parser.parse(res);
35
40
  } catch (e: any) {
36
41
  e.message += `\n When loading ${url}.`
37
42
  throw e;
@@ -46,6 +51,6 @@ export class PiRestService {
46
51
  requestInit.headers = {...authorizationHeader, ...requestInit.headers};
47
52
  }
48
53
  const res = await fetch(url, requestInit);
49
- return await this.processResponse(dataRequestResult, res, url);
54
+ return await this.processResponse(dataRequestResult, res, url, new DefaultParser());
50
55
  }
51
56
  }
@@ -1,3 +1,22 @@
1
- export default interface RequestOptions {
2
- cache: string;
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
  }