@deltares/fews-web-oc-utils 0.1.9 → 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.
@@ -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,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
+ !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,4 +1,5 @@
1
1
  import { DefaultParser } from "../parser";
2
+ import { RequestOptions } from "./requestOptions";
2
3
  export class PiRestService {
3
4
  webserviceUrl;
4
5
  _oauth2Token = undefined;
@@ -8,18 +9,21 @@ export class PiRestService {
8
9
  constructor(webserviceUrl) {
9
10
  this.webserviceUrl = webserviceUrl;
10
11
  }
11
- async getDataWithParser(url, parser) {
12
+ async getDataWithParser(url, requestOption, parser) {
13
+ const requestUrl = requestOption.relativeUrl ? this.webserviceUrl + url : url;
12
14
  const dataRequestResult = {};
13
15
  const requestParameters = {};
14
16
  requestParameters.method = "GET";
15
17
  if (this._oauth2Token !== undefined) {
16
18
  requestParameters.headers = { "Authorization": "Bearer " + this._oauth2Token };
17
19
  }
18
- const res = await fetch(url, requestParameters);
19
- return await this.processResponse(dataRequestResult, res, url, parser);
20
+ const res = await fetch(requestUrl, requestParameters);
21
+ return await this.processResponse(dataRequestResult, res, requestUrl, parser);
20
22
  }
21
23
  async getData(url) {
22
- return this.getDataWithParser(url, new DefaultParser());
24
+ const requestOption = new RequestOptions();
25
+ requestOption.relativeUrl = false;
26
+ return this.getDataWithParser(url, requestOption, new DefaultParser());
23
27
  }
24
28
  async processResponse(dataRequestResult, res, url, parser) {
25
29
  dataRequestResult.responseCode = res.status;
@@ -1 +1 @@
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
+ {"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,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,6 +1,6 @@
1
1
  {
2
2
  "name": "@deltares/fews-web-oc-utils",
3
- "version": "0.1.9",
3
+ "version": "0.1.10",
4
4
  "description": "Util Library for common Web OC functionality",
5
5
  "author": {
6
6
  "name": "Werner Kramer",
@@ -1,6 +1,7 @@
1
1
  import DataRequestResult from "./dataRequestResult";
2
2
  import {ResponseParser} from "../parser/responseParser";
3
3
  import {DefaultParser} from "../parser";
4
+ import {RequestOptions} from "./requestOptions";
4
5
 
5
6
  export class PiRestService {
6
7
  private readonly webserviceUrl: string;
@@ -14,19 +15,22 @@ export class PiRestService {
14
15
  this.webserviceUrl = webserviceUrl;
15
16
  }
16
17
 
17
- 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;
18
20
  const dataRequestResult = {} as DataRequestResult<T>;
19
21
  const requestParameters = {} as RequestInit;
20
22
  requestParameters.method = "GET";
21
23
  if (this._oauth2Token !== undefined) {
22
24
  requestParameters.headers = {"Authorization": "Bearer " + this._oauth2Token}
23
25
  }
24
- const res = await fetch(url,requestParameters);
25
- return await this.processResponse(dataRequestResult, res, url, parser);
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
- return this.getDataWithParser(url, new DefaultParser());
31
+ const requestOption = new RequestOptions()
32
+ requestOption.relativeUrl = false
33
+ return this.getDataWithParser(url, requestOption, new DefaultParser());
30
34
  }
31
35
 
32
36
  private async processResponse<T>(dataRequestResult: DataRequestResult<T>, res: Response, url: string, parser: ResponseParser<T>): Promise<DataRequestResult<T>> {