@osaas/client-core 0.2.0
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/LICENSE +21 -0
- package/README.md +52 -0
- package/lib/context.d.ts +27 -0
- package/lib/context.d.ts.map +1 -0
- package/lib/context.js +60 -0
- package/lib/context.js.map +1 -0
- package/lib/core.d.ts +4 -0
- package/lib/core.d.ts.map +1 -0
- package/lib/core.js +46 -0
- package/lib/core.js.map +1 -0
- package/lib/fetch.d.ts +12 -0
- package/lib/fetch.d.ts.map +1 -0
- package/lib/fetch.js +59 -0
- package/lib/fetch.js.map +1 -0
- package/lib/index.d.ts +5 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +13 -0
- package/lib/index.js.map +1 -0
- package/lib/log.d.ts +13 -0
- package/lib/log.d.ts.map +1 -0
- package/lib/log.js +91 -0
- package/lib/log.js.map +1 -0
- package/package.json +34 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 Eyevinn Technology Open Source Software Center
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
# @osaas/client-core
|
|
2
|
+
|
|
3
|
+
## Usage
|
|
4
|
+
|
|
5
|
+
### Launch a Chaos Stream Proxy
|
|
6
|
+
|
|
7
|
+
```javascript
|
|
8
|
+
import { Context, Log, createInstance } from '@osaas/client-core';
|
|
9
|
+
|
|
10
|
+
const ctx = new Context();
|
|
11
|
+
|
|
12
|
+
try {
|
|
13
|
+
const serviceAccessToken = await ctx.getServiceAccessToken(
|
|
14
|
+
'eyevinn-chaos-stream-proxy'
|
|
15
|
+
);
|
|
16
|
+
Log().info(serviceAccessToken);
|
|
17
|
+
|
|
18
|
+
const instance = await createInstance(
|
|
19
|
+
ctx,
|
|
20
|
+
'eyevinn-chaos-stream-proxy',
|
|
21
|
+
serviceAccessToken,
|
|
22
|
+
{ name: 'sdk' }
|
|
23
|
+
);
|
|
24
|
+
console.log(instance.url);
|
|
25
|
+
} catch (err) {
|
|
26
|
+
Log().error(err);
|
|
27
|
+
}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
### Remove a Chaos Stream Proxy
|
|
31
|
+
|
|
32
|
+
```javascript
|
|
33
|
+
import { Context, Log, removeInstance } from '@osaas/client-core';
|
|
34
|
+
|
|
35
|
+
const ctx = new Context();
|
|
36
|
+
|
|
37
|
+
try {
|
|
38
|
+
const serviceAccessToken = await ctx.getServiceAccessToken(
|
|
39
|
+
'eyevinn-chaos-stream-proxy'
|
|
40
|
+
);
|
|
41
|
+
Log().info(serviceAccessToken);
|
|
42
|
+
|
|
43
|
+
await removeInstance(
|
|
44
|
+
ctx,
|
|
45
|
+
'eyevinn-chaos-stream-proxy',
|
|
46
|
+
'sdk',
|
|
47
|
+
serviceAccessToken
|
|
48
|
+
);
|
|
49
|
+
} catch (err) {
|
|
50
|
+
Log().error(err);
|
|
51
|
+
}
|
|
52
|
+
```
|
package/lib/context.d.ts
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export type ContextConfig = {
|
|
2
|
+
personalAccessToken?: string;
|
|
3
|
+
environment?: string;
|
|
4
|
+
};
|
|
5
|
+
export type ServiceAccessToken = {
|
|
6
|
+
serviceId: string;
|
|
7
|
+
token: string;
|
|
8
|
+
expiry: number;
|
|
9
|
+
};
|
|
10
|
+
export type Service = {
|
|
11
|
+
serviceId: string;
|
|
12
|
+
apiUrl: string;
|
|
13
|
+
};
|
|
14
|
+
export type Subscriptions = {
|
|
15
|
+
teamId: string;
|
|
16
|
+
services: string[];
|
|
17
|
+
};
|
|
18
|
+
export declare class Context {
|
|
19
|
+
private personalAccessToken?;
|
|
20
|
+
private environment;
|
|
21
|
+
constructor(config?: ContextConfig);
|
|
22
|
+
getPersonalAccessToken(): string | undefined;
|
|
23
|
+
getEnvironment(): string;
|
|
24
|
+
getServiceAccessToken(serviceId: string): Promise<string>;
|
|
25
|
+
activateService(serviceId: string): Promise<void>;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,aAAa,GAAG;IAC1B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAEF,qBAAa,OAAO;IAClB,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,WAAW,CAAS;gBAEhB,MAAM,CAAC,EAAE,aAAa;IAalC,sBAAsB;IAItB,cAAc;IAIR,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA8BzD,eAAe,CAAC,SAAS,EAAE,MAAM;CAaxC"}
|
package/lib/context.js
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Context = void 0;
|
|
4
|
+
const fetch_1 = require("./fetch");
|
|
5
|
+
class Context {
|
|
6
|
+
personalAccessToken;
|
|
7
|
+
environment;
|
|
8
|
+
constructor(config) {
|
|
9
|
+
if (!config?.personalAccessToken && !process.env.OSC_ACCESS_TOKEN) {
|
|
10
|
+
throw new Error('Personal access token is required to create a context. Please provide it in the config or set the OSC_ACCESS_TOKEN environment variable.');
|
|
11
|
+
}
|
|
12
|
+
this.personalAccessToken = config?.personalAccessToken
|
|
13
|
+
? config.personalAccessToken
|
|
14
|
+
: process.env.OSC_ACCESS_TOKEN;
|
|
15
|
+
this.environment = config?.environment ? config.environment : 'prod';
|
|
16
|
+
}
|
|
17
|
+
getPersonalAccessToken() {
|
|
18
|
+
return this.personalAccessToken;
|
|
19
|
+
}
|
|
20
|
+
getEnvironment() {
|
|
21
|
+
return this.environment;
|
|
22
|
+
}
|
|
23
|
+
async getServiceAccessToken(serviceId) {
|
|
24
|
+
const serviceUrl = new URL(`https://catalog.svc.${this.environment}.osaas.io/mysubscriptions`);
|
|
25
|
+
const services = await (0, fetch_1.createFetch)(serviceUrl, {
|
|
26
|
+
method: 'GET',
|
|
27
|
+
headers: {
|
|
28
|
+
'x-pat-jwt': `Bearer ${this.personalAccessToken}`,
|
|
29
|
+
'Content-Type': 'application/json'
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
const service = services.find((svc) => svc.serviceId === serviceId);
|
|
33
|
+
if (!service) {
|
|
34
|
+
await this.activateService(serviceId);
|
|
35
|
+
}
|
|
36
|
+
const satUrl = new URL(`https://token.svc.${this.environment}.osaas.io/servicetoken`);
|
|
37
|
+
const serviceAccessToken = await (0, fetch_1.createFetch)(satUrl, {
|
|
38
|
+
method: 'POST',
|
|
39
|
+
body: JSON.stringify({ serviceId }),
|
|
40
|
+
headers: {
|
|
41
|
+
'x-pat-jwt': `Bearer ${this.personalAccessToken}`,
|
|
42
|
+
'Content-Type': 'application/json'
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
return serviceAccessToken.token;
|
|
46
|
+
}
|
|
47
|
+
async activateService(serviceId) {
|
|
48
|
+
const serviceUrl = new URL(`https://catalog.svc.${this.environment}.osaas.io/mysubscriptions`);
|
|
49
|
+
await (0, fetch_1.createFetch)(serviceUrl, {
|
|
50
|
+
method: 'POST',
|
|
51
|
+
body: JSON.stringify({ services: [serviceId] }),
|
|
52
|
+
headers: {
|
|
53
|
+
'x-pat-jwt': `Bearer ${this.personalAccessToken}`,
|
|
54
|
+
'Content-Type': 'application/json'
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.Context = Context;
|
|
60
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":";;;AAAA,mCAAsC;AAuBtC,MAAa,OAAO;IACV,mBAAmB,CAAU;IAC7B,WAAW,CAAS;IAE5B,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,EAAE,mBAAmB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE;YACjE,MAAM,IAAI,KAAK,CACb,0IAA0I,CAC3I,CAAC;SACH;QAED,IAAI,CAAC,mBAAmB,GAAG,MAAM,EAAE,mBAAmB;YACpD,CAAC,CAAC,MAAM,CAAC,mBAAmB;YAC5B,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;QACjC,IAAI,CAAC,WAAW,GAAG,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC;IACvE,CAAC;IAED,sBAAsB;QACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,qBAAqB,CAAC,SAAiB;QAC3C,MAAM,UAAU,GAAG,IAAI,GAAG,CACxB,uBAAuB,IAAI,CAAC,WAAW,2BAA2B,CACnE,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,IAAA,mBAAW,EAAY,UAAU,EAAE;YACxD,MAAM,EAAE,KAAK;YACb,OAAO,EAAE;gBACP,WAAW,EAAE,UAAU,IAAI,CAAC,mBAAmB,EAAE;gBACjD,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;QACpE,IAAI,CAAC,OAAO,EAAE;YACZ,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;SACvC;QAED,MAAM,MAAM,GAAG,IAAI,GAAG,CACpB,qBAAqB,IAAI,CAAC,WAAW,wBAAwB,CAC9D,CAAC;QACF,MAAM,kBAAkB,GAAG,MAAM,IAAA,mBAAW,EAAqB,MAAM,EAAE;YACvE,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,SAAS,EAAE,CAAC;YACnC,OAAO,EAAE;gBACP,WAAW,EAAE,UAAU,IAAI,CAAC,mBAAmB,EAAE;gBACjD,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAC;QACH,OAAO,kBAAkB,CAAC,KAAK,CAAC;IAClC,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAiB;QACrC,MAAM,UAAU,GAAG,IAAI,GAAG,CACxB,uBAAuB,IAAI,CAAC,WAAW,2BAA2B,CACnE,CAAC;QACF,MAAM,IAAA,mBAAW,EAAgB,UAAU,EAAE;YAC3C,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC;YAC/C,OAAO,EAAE;gBACP,WAAW,EAAE,UAAU,IAAI,CAAC,mBAAmB,EAAE;gBACjD,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAC;IACL,CAAC;CACF;AApED,0BAoEC"}
|
package/lib/core.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Context } from './context';
|
|
2
|
+
export declare function createInstance(context: Context, serviceId: string, token: string, body: any): Promise<any>;
|
|
3
|
+
export declare function removeInstance(context: Context, serviceId: string, name: string, token: string): Promise<void>;
|
|
4
|
+
//# sourceMappingURL=core.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAW,MAAM,WAAW,CAAC;AAqB7C,wBAAsB,cAAc,CAClC,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,GAAG,GACR,OAAO,CAAC,GAAG,CAAC,CAad;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,iBAYd"}
|
package/lib/core.js
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.removeInstance = exports.createInstance = void 0;
|
|
4
|
+
const fetch_1 = require("./fetch");
|
|
5
|
+
async function getService(context, serviceId) {
|
|
6
|
+
const serviceUrl = new URL(`https://catalog.svc.${context.getEnvironment()}.osaas.io/mysubscriptions`);
|
|
7
|
+
const services = await (0, fetch_1.createFetch)(serviceUrl, {
|
|
8
|
+
method: 'GET',
|
|
9
|
+
headers: {
|
|
10
|
+
'x-pat-jwt': `Bearer ${context.getPersonalAccessToken()}`,
|
|
11
|
+
'Content-Type': 'application/json'
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
const service = services.find((svc) => svc.serviceId === serviceId);
|
|
15
|
+
if (!service) {
|
|
16
|
+
throw new Error(`Service ${serviceId} not found in your subscriptions`);
|
|
17
|
+
}
|
|
18
|
+
return service;
|
|
19
|
+
}
|
|
20
|
+
async function createInstance(context, serviceId, token, body) {
|
|
21
|
+
const service = await getService(context, serviceId);
|
|
22
|
+
const instanceUrl = new URL(service.apiUrl);
|
|
23
|
+
const instance = await (0, fetch_1.createFetch)(instanceUrl, {
|
|
24
|
+
method: 'POST',
|
|
25
|
+
body: JSON.stringify(body),
|
|
26
|
+
headers: {
|
|
27
|
+
'x-jwt': `Bearer ${token}`,
|
|
28
|
+
'Content-Type': 'application/json'
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
return instance;
|
|
32
|
+
}
|
|
33
|
+
exports.createInstance = createInstance;
|
|
34
|
+
async function removeInstance(context, serviceId, name, token) {
|
|
35
|
+
const service = await getService(context, serviceId);
|
|
36
|
+
const instanceUrl = new URL(service.apiUrl + '/' + name);
|
|
37
|
+
await (0, fetch_1.createFetch)(instanceUrl, {
|
|
38
|
+
method: 'DELETE',
|
|
39
|
+
headers: {
|
|
40
|
+
'x-jwt': `Bearer ${token}`,
|
|
41
|
+
'Content-Type': 'application/json'
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
exports.removeInstance = removeInstance;
|
|
46
|
+
//# sourceMappingURL=core.js.map
|
package/lib/core.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":";;;AACA,mCAAsC;AAEtC,KAAK,UAAU,UAAU,CAAC,OAAgB,EAAE,SAAiB;IAC3D,MAAM,UAAU,GAAG,IAAI,GAAG,CACxB,uBAAuB,OAAO,CAAC,cAAc,EAAE,2BAA2B,CAC3E,CAAC;IACF,MAAM,QAAQ,GAAG,MAAM,IAAA,mBAAW,EAAY,UAAU,EAAE;QACxD,MAAM,EAAE,KAAK;QACb,OAAO,EAAE;YACP,WAAW,EAAE,UAAU,OAAO,CAAC,sBAAsB,EAAE,EAAE;YACzD,cAAc,EAAE,kBAAkB;SACnC;KACF,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;IACpE,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CAAC,WAAW,SAAS,kCAAkC,CAAC,CAAC;KACzE;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAEM,KAAK,UAAU,cAAc,CAClC,OAAgB,EAChB,SAAiB,EACjB,KAAa,EACb,IAAS;IAET,MAAM,OAAO,GAAG,MAAM,UAAU,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IACrD,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAE5C,MAAM,QAAQ,GAAG,MAAM,IAAA,mBAAW,EAAM,WAAW,EAAE;QACnD,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QAC1B,OAAO,EAAE;YACP,OAAO,EAAE,UAAU,KAAK,EAAE;YAC1B,cAAc,EAAE,kBAAkB;SACnC;KACF,CAAC,CAAC;IACH,OAAO,QAAQ,CAAC;AAClB,CAAC;AAlBD,wCAkBC;AAEM,KAAK,UAAU,cAAc,CAClC,OAAgB,EAChB,SAAiB,EACjB,IAAY,EACZ,KAAa;IAEb,MAAM,OAAO,GAAG,MAAM,UAAU,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IACrD,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,CAAC;IAEzD,MAAM,IAAA,mBAAW,EAAM,WAAW,EAAE;QAClC,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE;YACP,OAAO,EAAE,UAAU,KAAK,EAAE;YAC1B,cAAc,EAAE,kBAAkB;SACnC;KACF,CAAC,CAAC;AACL,CAAC;AAhBD,wCAgBC"}
|
package/lib/fetch.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
export type ErrorFactory = (response: Response) => Promise<FetchError>;
|
|
4
|
+
export declare const createFetch: <T>(url: string | URL, options?: RequestInit, errorFactory?: ErrorFactory) => Promise<T>;
|
|
5
|
+
export declare class FetchError extends Error {
|
|
6
|
+
httpCode?: number;
|
|
7
|
+
constructor({ message, httpCode }: {
|
|
8
|
+
message: string;
|
|
9
|
+
httpCode?: number;
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=fetch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../src/fetch.ts"],"names":[],"mappings":";;AASA,MAAM,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAkBvE,eAAO,MAAM,WAAW,WACjB,MAAM,GAAG,GAAG,YACP,WAAW,iBACP,YAAY,eAwB3B,CAAC;AAOF,qBAAa,UAAW,SAAQ,KAAK;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;gBAEN,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;CAI1E"}
|
package/lib/fetch.js
ADDED
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FetchError = exports.createFetch = void 0;
|
|
4
|
+
const log_1 = require("./log");
|
|
5
|
+
const defaultErrorFactory = async (response) => {
|
|
6
|
+
if (response.headers.get('content-type')?.includes('application/json')) {
|
|
7
|
+
const res = await response.json();
|
|
8
|
+
return new FetchError({
|
|
9
|
+
message: res?.message ?? res?.reason ?? JSON.stringify(res),
|
|
10
|
+
httpCode: response.status
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
const res = await response.text();
|
|
15
|
+
return new FetchError({
|
|
16
|
+
message: res,
|
|
17
|
+
httpCode: response.status
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
const createFetch = async (url, options, errorFactory = defaultErrorFactory) => {
|
|
22
|
+
try {
|
|
23
|
+
(0, log_1.Log)().debug(`${options?.method}: ${url}`);
|
|
24
|
+
const response = await fetch(url, { ...options });
|
|
25
|
+
if (!response.ok) {
|
|
26
|
+
throw await errorFactory(response);
|
|
27
|
+
}
|
|
28
|
+
if (response.headers.get('content-type')?.includes('application/json')) {
|
|
29
|
+
const res = await response.json();
|
|
30
|
+
return res;
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
const res = await response.text();
|
|
34
|
+
return res;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
if (error instanceof FetchError) {
|
|
39
|
+
(0, log_1.Log)().debug(error.httpCode + ': ' + error.message);
|
|
40
|
+
throw error;
|
|
41
|
+
}
|
|
42
|
+
throw new FetchError({ message: getErrorMessage(error) });
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
exports.createFetch = createFetch;
|
|
46
|
+
const getErrorMessage = (error) => {
|
|
47
|
+
if (error instanceof Error)
|
|
48
|
+
return error.message;
|
|
49
|
+
return JSON.stringify(error);
|
|
50
|
+
};
|
|
51
|
+
class FetchError extends Error {
|
|
52
|
+
httpCode;
|
|
53
|
+
constructor({ message, httpCode }) {
|
|
54
|
+
super(message);
|
|
55
|
+
this.httpCode = httpCode;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
exports.FetchError = FetchError;
|
|
59
|
+
//# sourceMappingURL=fetch.js.map
|
package/lib/fetch.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch.js","sourceRoot":"","sources":["../src/fetch.ts"],"names":[],"mappings":";;;AAAA,+BAA4B;AAW5B,MAAM,mBAAmB,GAAiB,KAAK,EAAE,QAAQ,EAAE,EAAE;IAC3D,IAAI,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,QAAQ,CAAC,kBAAkB,CAAC,EAAE;QACtE,MAAM,GAAG,GAAuB,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtD,OAAO,IAAI,UAAU,CAAC;YACpB,OAAO,EAAE,GAAG,EAAE,OAAO,IAAI,GAAG,EAAE,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;YAC3D,QAAQ,EAAE,QAAQ,CAAC,MAAM;SAC1B,CAAC,CAAC;KACJ;SAAM;QACL,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAClC,OAAO,IAAI,UAAU,CAAC;YACpB,OAAO,EAAE,GAAG;YACZ,QAAQ,EAAE,QAAQ,CAAC,MAAM;SAC1B,CAAC,CAAC;KACJ;AACH,CAAC,CAAC;AAEK,MAAM,WAAW,GAAG,KAAK,EAC9B,GAAiB,EACjB,OAAqB,EACrB,eAA6B,mBAAmB,EACpC,EAAE;IACd,IAAI;QACF,IAAA,SAAG,GAAE,CAAC,KAAK,CAAC,GAAG,OAAO,EAAE,MAAM,KAAK,GAAG,EAAE,CAAC,CAAC;QAC1C,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAElD,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;YAChB,MAAM,MAAM,YAAY,CAAC,QAAQ,CAAC,CAAC;SACpC;QAED,IAAI,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,QAAQ,CAAC,kBAAkB,CAAC,EAAE;YACtE,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YAClC,OAAO,GAAQ,CAAC;SACjB;aAAM;YACL,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YAClC,OAAO,GAAQ,CAAC;SACjB;KACF;IAAC,OAAO,KAAc,EAAE;QACvB,IAAI,KAAK,YAAY,UAAU,EAAE;YAC/B,IAAA,SAAG,GAAE,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC;YACnD,MAAM,KAAK,CAAC;SACb;QACD,MAAM,IAAI,UAAU,CAAC,EAAE,OAAO,EAAE,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;KAC3D;AACH,CAAC,CAAC;AA3BW,QAAA,WAAW,eA2BtB;AAEF,MAAM,eAAe,GAAG,CAAC,KAAc,EAAE,EAAE;IACzC,IAAI,KAAK,YAAY,KAAK;QAAE,OAAO,KAAK,CAAC,OAAO,CAAC;IACjD,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAa,UAAW,SAAQ,KAAK;IACnC,QAAQ,CAAU;IAElB,YAAY,EAAE,OAAO,EAAE,QAAQ,EAA0C;QACvE,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;CACF;AAPD,gCAOC"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC"}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.removeInstance = exports.createInstance = exports.Context = exports.createFetch = exports.Log = void 0;
|
|
4
|
+
var log_1 = require("./log");
|
|
5
|
+
Object.defineProperty(exports, "Log", { enumerable: true, get: function () { return log_1.Log; } });
|
|
6
|
+
var fetch_1 = require("./fetch");
|
|
7
|
+
Object.defineProperty(exports, "createFetch", { enumerable: true, get: function () { return fetch_1.createFetch; } });
|
|
8
|
+
var context_1 = require("./context");
|
|
9
|
+
Object.defineProperty(exports, "Context", { enumerable: true, get: function () { return context_1.Context; } });
|
|
10
|
+
var core_1 = require("./core");
|
|
11
|
+
Object.defineProperty(exports, "createInstance", { enumerable: true, get: function () { return core_1.createInstance; } });
|
|
12
|
+
Object.defineProperty(exports, "removeInstance", { enumerable: true, get: function () { return core_1.removeInstance; } });
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,6BAA4B;AAAnB,0FAAA,GAAG,OAAA;AACZ,iCAAsC;AAA7B,oGAAA,WAAW,OAAA;AACpB,qCAAoC;AAA3B,kGAAA,OAAO,OAAA;AAChB,+BAAwD;AAA/C,sGAAA,cAAc,OAAA;AAAE,sGAAA,cAAc,OAAA"}
|
package/lib/log.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class Logger {
|
|
2
|
+
private debugMode;
|
|
3
|
+
constructor();
|
|
4
|
+
info(...args: any[]): this;
|
|
5
|
+
warn(...args: any[]): this;
|
|
6
|
+
error(...args: any[]): this;
|
|
7
|
+
debug(...args: any[]): this;
|
|
8
|
+
fatal(...args: any[]): this;
|
|
9
|
+
get level(): 'debug' | 'info';
|
|
10
|
+
set level(value: 'debug' | 'info');
|
|
11
|
+
}
|
|
12
|
+
export declare function Log(): Logger;
|
|
13
|
+
//# sourceMappingURL=log.d.ts.map
|
package/lib/log.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.d.ts","sourceRoot":"","sources":["../src/log.ts"],"names":[],"mappings":"AAwCA,qBAAa,MAAM;IACjB,OAAO,CAAC,SAAS,CAAS;;IAM1B,IAAI,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE;IAKnB,IAAI,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE;IAKnB,KAAK,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE;IAKpB,KAAK,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE;IAKpB,KAAK,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE;IAKpB,IAAI,KAAK,IAAI,OAAO,GAAG,MAAM,CAE5B;IAED,IAAI,KAAK,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,EAQhC;CACF;AAED,wBAAgB,GAAG,IAAI,MAAM,CAa5B"}
|
package/lib/log.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Log = exports.Logger = void 0;
|
|
7
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
8
|
+
const util_1 = __importDefault(require("util"));
|
|
9
|
+
let logger_;
|
|
10
|
+
const LEVELS = {
|
|
11
|
+
info: { text: 'info', method: 'info', color: 'white' },
|
|
12
|
+
error: { text: 'error', method: 'error', color: 'red' },
|
|
13
|
+
warn: { text: 'warn', method: 'info', color: 'yellow' },
|
|
14
|
+
debug: { text: 'debug', method: 'info', color: 'blue' },
|
|
15
|
+
fatal: { text: 'fatal', method: 'error', color: 'redBright' }
|
|
16
|
+
};
|
|
17
|
+
function log(method) {
|
|
18
|
+
switch (method) {
|
|
19
|
+
case 'info':
|
|
20
|
+
return console.info;
|
|
21
|
+
case 'error':
|
|
22
|
+
return console.error;
|
|
23
|
+
default:
|
|
24
|
+
throw new Error(`Invalid log method ${method}`);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
function logfmt(levelCode, ...args) {
|
|
28
|
+
const level = LEVELS[levelCode];
|
|
29
|
+
if (levelCode == 'debug') {
|
|
30
|
+
log(level.method)(...args);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
const msg = util_1.default.format(...args);
|
|
34
|
+
log(level.method)(chalk_1.default[level.color](msg));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
class Logger {
|
|
38
|
+
debugMode = false;
|
|
39
|
+
constructor() {
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
info(...args) {
|
|
43
|
+
logfmt('info', ...args);
|
|
44
|
+
return this;
|
|
45
|
+
}
|
|
46
|
+
warn(...args) {
|
|
47
|
+
logfmt('warn', ...args);
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
error(...args) {
|
|
51
|
+
logfmt('error', ...args);
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
debug(...args) {
|
|
55
|
+
if (this.debugMode)
|
|
56
|
+
logfmt('debug', ...args);
|
|
57
|
+
return this;
|
|
58
|
+
}
|
|
59
|
+
fatal(...args) {
|
|
60
|
+
logfmt('fatal', ...args);
|
|
61
|
+
return this;
|
|
62
|
+
}
|
|
63
|
+
get level() {
|
|
64
|
+
return this.debugMode ? 'debug' : 'info';
|
|
65
|
+
}
|
|
66
|
+
set level(value) {
|
|
67
|
+
if (value == 'debug') {
|
|
68
|
+
this.debugMode = true;
|
|
69
|
+
}
|
|
70
|
+
else if (value == 'info') {
|
|
71
|
+
this.debugMode = false;
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
this.warn('level', value, 'not supported');
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.Logger = Logger;
|
|
79
|
+
function Log() {
|
|
80
|
+
if (logger_) {
|
|
81
|
+
return logger_;
|
|
82
|
+
}
|
|
83
|
+
logger_ = new Logger();
|
|
84
|
+
logger_.level = 'info';
|
|
85
|
+
if (process.env.DEBUG) {
|
|
86
|
+
logger_.level = 'debug';
|
|
87
|
+
}
|
|
88
|
+
return logger_;
|
|
89
|
+
}
|
|
90
|
+
exports.Log = Log;
|
|
91
|
+
//# sourceMappingURL=log.js.map
|
package/lib/log.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.js","sourceRoot":"","sources":["../src/log.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@osaas/client-core",
|
|
3
|
+
"version": "0.2.0",
|
|
4
|
+
"description": "Open Source Cloud Client SDK core library",
|
|
5
|
+
"author": "Eyevinn Technology <work@eyevinn.se>",
|
|
6
|
+
"homepage": "https://www.osaas.io",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"main": "lib/index.js",
|
|
9
|
+
"types": "lib/index.d.ts",
|
|
10
|
+
"repository": {
|
|
11
|
+
"type": "git",
|
|
12
|
+
"url": "git+https://github.com/Eyevinn/osaas-client-ts.git"
|
|
13
|
+
},
|
|
14
|
+
"directories": {
|
|
15
|
+
"lib": "lib"
|
|
16
|
+
},
|
|
17
|
+
"files": [
|
|
18
|
+
"lib"
|
|
19
|
+
],
|
|
20
|
+
"scripts": {
|
|
21
|
+
"build": "tsc -p tsconfig.json",
|
|
22
|
+
"lint": "eslint .",
|
|
23
|
+
"pretty": "prettier --check --ignore-unknown .",
|
|
24
|
+
"typecheck": "tsc --noEmit -p tsconfig.json",
|
|
25
|
+
"test": "jest"
|
|
26
|
+
},
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"chalk": "4.1.2"
|
|
29
|
+
},
|
|
30
|
+
"publishConfig": {
|
|
31
|
+
"access": "public"
|
|
32
|
+
},
|
|
33
|
+
"gitHead": "d552f858037c6a99bdd9f8dc669bf5f82a90e396"
|
|
34
|
+
}
|