@shinkashi/insight-sdk
Version:
Solution Insight SDK for JavaScript
175 lines (174 loc) • 7.8 kB
JavaScript
;
var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }
var __asyncValues = (this && this.__asyncValues) || function (o) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
};
var __asyncDelegator = (this && this.__asyncDelegator) || function (o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
};
var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.InsightResourceRepository = void 0;
const repository_1 = require("./repository");
class InsightResourceRepository extends repository_1.InsightRepository {
async getByName(name) {
const res = this.query({
queries: [{
key: "base.name",
modifier: 'exact',
values: [name]
}]
});
const obj = await (await res.next()).value;
if (!obj) {
throw new Error(`getByName Error: No resource "${name}" found `);
}
return obj;
}
query(query) {
return __asyncGenerator(this, arguments, function* query_1() {
let page = 1;
while (true) {
const response = yield __await(this.client.ax.post("/query", Object.assign({ page: page, per_page: 100 }, query)));
if (response.status != 200) {
throw new Error(`API Error ${response.status}: ${response.data}`);
}
const items = response.data.items;
if (items.length === 0)
break;
yield __await(yield* __asyncDelegator(__asyncValues(items)));
page++;
}
return yield __await(undefined);
});
}
async queryAll(query) {
// Please use this only when we know the number of resources are small.
// https://stackoverflow.com/questions/58668361/how-can-i-convert-an-async-iterator-to-an-array
var e_1, _a;
const resources = [];
try {
for (var _b = __asyncValues(this.query(query)), _c; _c = await _b.next(), !_c.done;) {
const resource = _c.value;
resources.push(resource);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) await _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
return resources;
}
async getMetadata(resourceID, namespace = 'default') {
// GET /resources/id/metadata/namespace response
// Current production (except Sandbox)
let metadata = { [namespace]: {} };
const path = `${this.objPath}/${resourceID}/metadata/${namespace}`;
const response = await this.client.ax.get(path);
if (response.status != 200) {
throw new Error(`API Error ${response.status}: ${response.data}`);
}
metadata[namespace] = this.parseMetadataApiItems(response.data);
return metadata;
}
async setMetadata(resourceID, metadata) {
for (const namespace in metadata) {
const body = this.buildMetadataApiItems(metadata[namespace]);
const path = `${this.objPath}/${resourceID}/metadata/${namespace}`;
const response = await this.client.ax.put(path, body);
if (response.status != 200) {
throw new Error(`API Error ${response.status}: ${response.data}`);
}
}
}
async addMetadata(resourceIDs, metadata) {
// POST /resources/assign. Supporting multuple namespaces
for (const namespace in metadata) {
const body = {
resources: resourceIDs,
namespace,
metadata: this.buildMetadataApiItems(metadata[namespace])
};
const path = `${this.objPath}/metadata/assign`;
try {
const response = await this.client.ax.post(path, body);
}
catch (e) {
throw new Error(`API Error ${e}`);
}
// if (response.status != 200) {
// throw new Error(`API Error ${response.status}: ${response.data}`)
// }
}
}
async removeMetadata(resourceIDs, namespace, keys) {
// POST /resources/unassign. Supporting only one namespace at a time
const body = {
resources: resourceIDs,
namespace,
keys,
};
const path = `${this.objPath}/metadata/unassign`;
const response = await this.client.ax.post(path, body);
if (response.status != 200) {
throw new Error(`API Error ${response.status}: ${response.data}`);
}
}
/**
* Convert metadata to metadataApiItem[] for buildling API requests.
*
* @params {key1: value1, key2: value2}
* @returns [
* {key: key1, value: value1, value_type: text},
* {key: key2, value: value2, value_type: text}
* ]
*/
buildMetadataApiItems(kv) {
return Object.entries(kv).map(([key, value]) => {
switch (typeof value) {
case 'string':
return { key, value, value_type: 'text' };
default:
// No need to jsonify value, Axios does
return { key, value, value_type: 'json' };
}
;
});
}
/**
* Convert metadataApiItem[] to {key:value} for parsing API responses.
*
* @params [
* {key: key1, value: value1, value_type: text},
* {key: key2, value: value2, value_type: text}
* ]
* @returns {key1: value1, key2: value2}
*/
parseMetadataApiItems(items) {
const kv = {};
for (const item of items) {
kv[item.key] = item.value;
}
return kv;
}
}
exports.InsightResourceRepository = InsightResourceRepository;