@nsshunt/stsfhirpg 1.2.31 → 1.2.33
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/index.cjs
CHANGED
|
@@ -6223,9 +6223,20 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6223
6223
|
return true;
|
|
6224
6224
|
}
|
|
6225
6225
|
async EndDatabase() {
|
|
6226
|
-
if (this.#poolManager)
|
|
6227
|
-
|
|
6228
|
-
|
|
6226
|
+
if (!this.#poolManager) {
|
|
6227
|
+
const errorMessage = `EndDatabase(): poolManager not set`;
|
|
6228
|
+
this.#options.logger.error(errorMessage);
|
|
6229
|
+
throw new Error(errorMessage);
|
|
6230
|
+
}
|
|
6231
|
+
try {
|
|
6232
|
+
await this.#poolManager.End();
|
|
6233
|
+
this.#poolManager = null;
|
|
6234
|
+
return true;
|
|
6235
|
+
} catch (error) {
|
|
6236
|
+
const message = `PGFhirAccessLayer:EndDatabase(): Error: [${error}]`;
|
|
6237
|
+
this.#options.logger.error(message);
|
|
6238
|
+
throw new Error(message);
|
|
6239
|
+
}
|
|
6229
6240
|
}
|
|
6230
6241
|
GetFhirResourceController = () => {
|
|
6231
6242
|
return this.#dbSTSResource;
|
|
@@ -6236,176 +6247,184 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6236
6247
|
UpdateIndexes = async (client, resource) => {
|
|
6237
6248
|
let start = performance.now();
|
|
6238
6249
|
const oa = start;
|
|
6239
|
-
|
|
6240
|
-
|
|
6241
|
-
|
|
6242
|
-
|
|
6243
|
-
|
|
6244
|
-
|
|
6245
|
-
|
|
6246
|
-
|
|
6247
|
-
|
|
6248
|
-
|
|
6249
|
-
|
|
6250
|
-
|
|
6251
|
-
|
|
6252
|
-
|
|
6253
|
-
|
|
6254
|
-
|
|
6255
|
-
await this.#
|
|
6256
|
-
|
|
6257
|
-
|
|
6258
|
-
|
|
6259
|
-
|
|
6260
|
-
|
|
6261
|
-
|
|
6262
|
-
|
|
6263
|
-
|
|
6264
|
-
|
|
6265
|
-
|
|
6266
|
-
|
|
6267
|
-
|
|
6268
|
-
|
|
6269
|
-
|
|
6270
|
-
|
|
6271
|
-
|
|
6272
|
-
|
|
6273
|
-
|
|
6274
|
-
|
|
6275
|
-
|
|
6276
|
-
|
|
6277
|
-
|
|
6278
|
-
|
|
6279
|
-
|
|
6280
|
-
|
|
6281
|
-
})
|
|
6282
|
-
|
|
6283
|
-
|
|
6284
|
-
|
|
6285
|
-
}
|
|
6286
|
-
|
|
6287
|
-
RES_ID: resource.id,
|
|
6288
|
-
RES_TYPE: resource.resourceType
|
|
6289
|
-
});
|
|
6290
|
-
await this.#dbSTSUri.DeleteRecord(client, {
|
|
6291
|
-
RES_ID: resource.id,
|
|
6292
|
-
RES_TYPE: resource.resourceType
|
|
6293
|
-
});
|
|
6294
|
-
await this.#dbSTSCombo.DeleteRecord(client, {
|
|
6295
|
-
RES_ID: resource.id,
|
|
6296
|
-
RES_TYPE: resource.resourceType
|
|
6297
|
-
});
|
|
6298
|
-
const lap2 = performance.now() - start;
|
|
6299
|
-
start = performance.now();
|
|
6250
|
+
let lap1;
|
|
6251
|
+
let lap2;
|
|
6252
|
+
let lap3;
|
|
6253
|
+
let searchIndexData;
|
|
6254
|
+
try {
|
|
6255
|
+
searchIndexData = await this.#dbSearchIndex.GetSearchIndexData(resource);
|
|
6256
|
+
lap1 = performance.now() - start;
|
|
6257
|
+
start = performance.now();
|
|
6258
|
+
await this.#dbSTSResourceLink.DeleteResourceLinkRecord(client, {
|
|
6259
|
+
RES_ID: resource.id,
|
|
6260
|
+
RES_TYPE: resource.resourceType
|
|
6261
|
+
});
|
|
6262
|
+
await this.#dbSTSString.DeleteRecord(client, {
|
|
6263
|
+
RES_ID: resource.id,
|
|
6264
|
+
RES_TYPE: resource.resourceType
|
|
6265
|
+
});
|
|
6266
|
+
await this.#dbSTSToken.DeleteRecord(client, {
|
|
6267
|
+
RES_ID: resource.id,
|
|
6268
|
+
RES_TYPE: resource.resourceType
|
|
6269
|
+
});
|
|
6270
|
+
await this.#dbSTSQuantity.DeleteRecord(client, {
|
|
6271
|
+
RES_ID: resource.id,
|
|
6272
|
+
RES_TYPE: resource.resourceType
|
|
6273
|
+
});
|
|
6274
|
+
await this.#dbSTSNumber.DeleteRecord(client, {
|
|
6275
|
+
RES_ID: resource.id,
|
|
6276
|
+
RES_TYPE: resource.resourceType
|
|
6277
|
+
});
|
|
6278
|
+
await this.#dbSTSDate.DeleteRecord(client, {
|
|
6279
|
+
RES_ID: resource.id,
|
|
6280
|
+
RES_TYPE: resource.resourceType
|
|
6281
|
+
});
|
|
6282
|
+
await this.#dbSTSUri.DeleteRecord(client, {
|
|
6283
|
+
RES_ID: resource.id,
|
|
6284
|
+
RES_TYPE: resource.resourceType
|
|
6285
|
+
});
|
|
6286
|
+
await this.#dbSTSCombo.DeleteRecord(client, {
|
|
6287
|
+
RES_ID: resource.id,
|
|
6288
|
+
RES_TYPE: resource.resourceType
|
|
6289
|
+
});
|
|
6290
|
+
lap2 = performance.now() - start;
|
|
6291
|
+
start = performance.now();
|
|
6292
|
+
} catch (error) {
|
|
6293
|
+
const message = `PGFhirAccessLayer:UpdateIndexes():lap1: Error: [${error}]`;
|
|
6294
|
+
this.#options.logger.error(message);
|
|
6295
|
+
throw new Error(message);
|
|
6296
|
+
}
|
|
6297
|
+
let si = void 0;
|
|
6300
6298
|
try {
|
|
6301
6299
|
for (let i = 0; i < searchIndexData.length; i++) {
|
|
6302
|
-
|
|
6300
|
+
si = searchIndexData[i];
|
|
6303
6301
|
performance.now();
|
|
6304
|
-
if (si && si.SP_MISSING) {}
|
|
6305
6302
|
switch (si.SP_PARAM_TYPE) {
|
|
6306
6303
|
case "reference":
|
|
6307
|
-
await
|
|
6304
|
+
await this.#dbSTSResourceLink.InsertResourceLink(client, si);
|
|
6308
6305
|
break;
|
|
6309
6306
|
case "string":
|
|
6310
|
-
await
|
|
6307
|
+
await this.#dbSTSString.InsertRecord(client, si);
|
|
6311
6308
|
break;
|
|
6312
6309
|
case "token":
|
|
6313
|
-
await
|
|
6310
|
+
await this.#dbSTSToken.InsertRecord(client, si);
|
|
6314
6311
|
break;
|
|
6315
6312
|
case "quantity":
|
|
6316
|
-
await
|
|
6313
|
+
await this.#dbSTSQuantity.InsertRecord(client, si);
|
|
6317
6314
|
break;
|
|
6318
6315
|
case "number":
|
|
6319
|
-
await
|
|
6316
|
+
await this.#dbSTSNumber.InsertRecord(client, si);
|
|
6320
6317
|
break;
|
|
6321
6318
|
case "date":
|
|
6322
|
-
await
|
|
6319
|
+
await this.#dbSTSDate.InsertRecord(client, si);
|
|
6323
6320
|
break;
|
|
6324
6321
|
case "uri":
|
|
6325
|
-
await
|
|
6322
|
+
await this.#dbSTSUri.InsertRecord(client, si);
|
|
6326
6323
|
break;
|
|
6327
6324
|
case "composite":
|
|
6328
|
-
await
|
|
6325
|
+
await this.#dbSTSCombo.InsertRecord(client, si);
|
|
6329
6326
|
break;
|
|
6330
6327
|
default:
|
|
6331
6328
|
}
|
|
6332
6329
|
}
|
|
6333
6330
|
} catch (error) {
|
|
6334
|
-
|
|
6331
|
+
let message;
|
|
6332
|
+
if (si) message = `PGFhirAccessLayer:UpdateIndexes():lap2: Param Type: [${si.SP_PARAM_TYPE}], Error: [${error}]`;
|
|
6333
|
+
else message = `PGFhirAccessLayer:UpdateIndexes():lap2: Param Type: [undefined], Error: [${error}]`;
|
|
6334
|
+
this.#options.logger.error(message);
|
|
6335
|
+
throw new Error(message);
|
|
6335
6336
|
}
|
|
6336
|
-
|
|
6337
|
+
lap3 = performance.now() - start;
|
|
6337
6338
|
const total = performance.now() - oa;
|
|
6338
|
-
|
|
6339
|
-
|
|
6340
|
-
|
|
6341
|
-
|
|
6342
|
-
|
|
6343
|
-
|
|
6344
|
-
|
|
6345
|
-
|
|
6339
|
+
try {
|
|
6340
|
+
if (total > 1e3) console.log(chalk.default.hex("#ff0400")(`--> Very Slow: O/A:[${total.toFixed(2)}] Index Calc:[${lap1.toFixed(2)}] Delete:[${lap2.toFixed(2)}] Insert:[${lap3.toFixed(2)}] ResourceType: [${resource.resourceType}]`));
|
|
6341
|
+
else if (total > 100) console.log(chalk.default.hex("#E33A36")(`--> Slow: O/A:[${total.toFixed(2)}] Index Calc:[${lap1.toFixed(2)}] Delete:[${lap2.toFixed(2)}] Insert:[${lap3.toFixed(2)}] ResourceType: [${resource.resourceType}]`));
|
|
6342
|
+
else if (total > 75) console.log(chalk.default.hex("#e27270")(`--> Slow: O/A:[${total.toFixed(2)}] Index Calc:[${lap1.toFixed(2)}] Delete:[${lap2.toFixed(2)}] Insert:[${lap3.toFixed(2)}] ResourceType: [${resource.resourceType}]`));
|
|
6343
|
+
else if (total > 50) console.log(chalk.default.hex("#e2c3c2")(`--> Slow: O/A:[${total.toFixed(2)}] Index Calc:[${lap1.toFixed(2)}] Delete:[${lap2.toFixed(2)}] Insert:[${lap3.toFixed(2)}] ResourceType: [${resource.resourceType}]`));
|
|
6344
|
+
} catch (error) {
|
|
6345
|
+
const message = `PGFhirAccessLayer:UpdateIndexes():lap3: Error: [${error}]`;
|
|
6346
|
+
this.#options.logger.error(message);
|
|
6347
|
+
throw new Error(message);
|
|
6348
|
+
}
|
|
6346
6349
|
};
|
|
6347
6350
|
BeginTransaction = async () => {
|
|
6348
|
-
if (this.#poolManager)
|
|
6349
|
-
const
|
|
6350
|
-
|
|
6351
|
-
|
|
6352
|
-
|
|
6353
|
-
|
|
6354
|
-
|
|
6355
|
-
|
|
6356
|
-
|
|
6357
|
-
client.release();
|
|
6358
|
-
delete this.#transactions[transactionHandle];
|
|
6359
|
-
}, this.#maxTransactionTime)
|
|
6360
|
-
};
|
|
6361
|
-
return transactionHandle;
|
|
6362
|
-
} catch (error) {
|
|
6363
|
-
console.error(error);
|
|
6364
|
-
client.release();
|
|
6365
|
-
}
|
|
6351
|
+
if (!this.#poolManager) {
|
|
6352
|
+
const errorMessage = `PGFhirAccessLayer:BeginTransaction(): poolManager not set`;
|
|
6353
|
+
this.#options.logger.error(errorMessage);
|
|
6354
|
+
throw new Error(errorMessage);
|
|
6355
|
+
}
|
|
6356
|
+
let transactionHandle = (0, node_crypto.randomUUID)();
|
|
6357
|
+
let client;
|
|
6358
|
+
try {
|
|
6359
|
+
client = await this.#poolManager.connectReadWrite();
|
|
6366
6360
|
} catch (error) {
|
|
6367
|
-
|
|
6361
|
+
const errorMessage = `PGFhirAccessLayer:BeginTransaction(): connectReadWrite: Error: [${error}]`;
|
|
6362
|
+
this.#options.logger.error(errorMessage);
|
|
6363
|
+
throw new Error(errorMessage);
|
|
6364
|
+
}
|
|
6365
|
+
try {
|
|
6366
|
+
await client.query("BEGIN");
|
|
6367
|
+
this.#transactions[transactionHandle] = {
|
|
6368
|
+
client,
|
|
6369
|
+
timeout: setTimeout(async () => {
|
|
6370
|
+
await this.#transactions[transactionHandle].client.query("ROLLBACK");
|
|
6371
|
+
client.release();
|
|
6372
|
+
delete this.#transactions[transactionHandle];
|
|
6373
|
+
const errorMessage = `PGFhirAccessLayer:BeginTransaction(): Error: [Transaction [${transactionHandle}] timeout. Timeout value: [${this.#maxTransactionTime}]]`;
|
|
6374
|
+
this.#options.logger.error(errorMessage);
|
|
6375
|
+
}, this.#maxTransactionTime)
|
|
6376
|
+
};
|
|
6377
|
+
return transactionHandle;
|
|
6378
|
+
} catch (error) {
|
|
6379
|
+
client.release();
|
|
6380
|
+
const errorMessage = `PGFhirAccessLayer:BeginTransaction(): Error: [${error}]`;
|
|
6381
|
+
this.#options.logger.error(errorMessage);
|
|
6382
|
+
throw new Error(errorMessage);
|
|
6368
6383
|
}
|
|
6369
6384
|
};
|
|
6370
6385
|
CommitTransaction = async (transactionHandle) => {
|
|
6371
6386
|
if (this.#transactions[transactionHandle]) {
|
|
6372
|
-
|
|
6373
|
-
const client = this.#transactions[transactionHandle].client;
|
|
6387
|
+
let client = void 0;
|
|
6374
6388
|
try {
|
|
6389
|
+
clearInterval(this.#transactions[transactionHandle].timeout);
|
|
6390
|
+
client = this.#transactions[transactionHandle].client;
|
|
6375
6391
|
await client.query("COMMIT");
|
|
6376
6392
|
client.release();
|
|
6377
6393
|
delete this.#transactions[transactionHandle];
|
|
6378
6394
|
return true;
|
|
6379
6395
|
} catch (error) {
|
|
6380
|
-
|
|
6381
|
-
client.release();
|
|
6396
|
+
if (client) client.release();
|
|
6382
6397
|
delete this.#transactions[transactionHandle];
|
|
6383
|
-
|
|
6398
|
+
const errorMessage = `PGFhirAccessLayer:CommitTransaction(): Error: [${error}]`;
|
|
6399
|
+
this.#options.logger.error(errorMessage);
|
|
6400
|
+
throw new Error(errorMessage);
|
|
6384
6401
|
}
|
|
6385
6402
|
}
|
|
6386
6403
|
return false;
|
|
6387
6404
|
};
|
|
6388
6405
|
RollbackTransaction = async (transactionHandle) => {
|
|
6389
6406
|
if (this.#transactions[transactionHandle]) {
|
|
6390
|
-
|
|
6391
|
-
const client = this.#transactions[transactionHandle].client;
|
|
6407
|
+
let client = void 0;
|
|
6392
6408
|
try {
|
|
6409
|
+
clearInterval(this.#transactions[transactionHandle].timeout);
|
|
6410
|
+
client = this.#transactions[transactionHandle].client;
|
|
6393
6411
|
await client.query("ROLLBACK");
|
|
6394
6412
|
client.release();
|
|
6395
6413
|
delete this.#transactions[transactionHandle];
|
|
6396
6414
|
return true;
|
|
6397
6415
|
} catch (error) {
|
|
6398
|
-
|
|
6399
|
-
client.release();
|
|
6416
|
+
if (client) client.release();
|
|
6400
6417
|
delete this.#transactions[transactionHandle];
|
|
6401
|
-
|
|
6418
|
+
const errorMessage = `PGFhirAccessLayer:RollbackTransaction(): Error: [${error}]`;
|
|
6419
|
+
this.#options.logger.error(errorMessage);
|
|
6420
|
+
throw new Error(errorMessage);
|
|
6402
6421
|
}
|
|
6403
6422
|
}
|
|
6404
6423
|
return false;
|
|
6405
6424
|
};
|
|
6406
6425
|
CreateResource = async (resource, transactionHandle) => {
|
|
6407
6426
|
if (!this.#poolManager) {
|
|
6408
|
-
const errorMessage = `CreateResource(): poolManager not set`;
|
|
6427
|
+
const errorMessage = `PGFhirAccessLayer:CreateResource(): poolManager not set`;
|
|
6409
6428
|
this.#options.logger.error(errorMessage);
|
|
6410
6429
|
throw new Error(errorMessage);
|
|
6411
6430
|
}
|
|
@@ -6420,7 +6439,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6420
6439
|
useTransaction = true;
|
|
6421
6440
|
}
|
|
6422
6441
|
} catch (error) {
|
|
6423
|
-
const errorMessage = `CreateResource(): Could not get connection: Error: [${error}]`;
|
|
6442
|
+
const errorMessage = `PGFhirAccessLayer:CreateResource(): Could not get connection: Error: [${error}]`;
|
|
6424
6443
|
this.#options.logger.error(errorMessage);
|
|
6425
6444
|
throw new Error(errorMessage);
|
|
6426
6445
|
}
|
|
@@ -6441,7 +6460,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6441
6460
|
RES_UPDATED: now
|
|
6442
6461
|
});
|
|
6443
6462
|
if (newVersion === void 0) {
|
|
6444
|
-
const errorMessage = `CreateResource(): Version Conflict. newVersion is undefined.`;
|
|
6463
|
+
const errorMessage = `PGFhirAccessLayer:CreateResource(): Version Conflict. newVersion is undefined.`;
|
|
6445
6464
|
this.#options.logger.error(errorMessage);
|
|
6446
6465
|
throw new Error(errorMessage);
|
|
6447
6466
|
}
|
|
@@ -6459,7 +6478,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6459
6478
|
OPERATION: "POST",
|
|
6460
6479
|
RES
|
|
6461
6480
|
}) === void 0) {
|
|
6462
|
-
const errorMessage = `CreateResource(): Version Conflict. resourceVersionRunResult is undefined.`;
|
|
6481
|
+
const errorMessage = `PGFhirAccessLayer:CreateResource(): Version Conflict. resourceVersionRunResult is undefined.`;
|
|
6463
6482
|
this.#options.logger.error(errorMessage);
|
|
6464
6483
|
throw new Error(errorMessage);
|
|
6465
6484
|
}
|
|
@@ -6469,7 +6488,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6469
6488
|
return resource;
|
|
6470
6489
|
} catch (error) {
|
|
6471
6490
|
if (useTransaction) await client.query("ROLLBACK");
|
|
6472
|
-
const errorMessage = `CreateResource(): Error: [${error}]`;
|
|
6491
|
+
const errorMessage = `PGFhirAccessLayer:CreateResource(): Error: [${error}]`;
|
|
6473
6492
|
this.#options.logger.error(errorMessage);
|
|
6474
6493
|
throw new Error(errorMessage);
|
|
6475
6494
|
} finally {
|
|
@@ -6478,7 +6497,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6478
6497
|
};
|
|
6479
6498
|
UpdateResource = async (resource, RES_VER, operation, transactionHandle) => {
|
|
6480
6499
|
if (!this.#poolManager) {
|
|
6481
|
-
const errorMessage = `UpdateResource(): poolManager not set`;
|
|
6500
|
+
const errorMessage = `PGFhirAccessLayer:UpdateResource(): poolManager not set`;
|
|
6482
6501
|
this.#options.logger.error(errorMessage);
|
|
6483
6502
|
throw new Error(errorMessage);
|
|
6484
6503
|
}
|
|
@@ -6493,7 +6512,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6493
6512
|
useTransaction = true;
|
|
6494
6513
|
}
|
|
6495
6514
|
} catch (error) {
|
|
6496
|
-
const errorMessage = `UpdateResource(): Could not get connection: Error: [${error}]`;
|
|
6515
|
+
const errorMessage = `PGFhirAccessLayer:UpdateResource(): Could not get connection: Error: [${error}]`;
|
|
6497
6516
|
this.#options.logger.error(errorMessage);
|
|
6498
6517
|
throw new Error(errorMessage);
|
|
6499
6518
|
}
|
|
@@ -6509,7 +6528,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6509
6528
|
RES_UPDATED: now
|
|
6510
6529
|
});
|
|
6511
6530
|
if (newVersion === void 0) {
|
|
6512
|
-
const errorMessage = `UpdateResource(): Version Conflict. newVersion is undefined. RES_VER: [${RES_VER}]`;
|
|
6531
|
+
const errorMessage = `PGFhirAccessLayer:UpdateResource(): Version Conflict. newVersion is undefined. RES_VER: [${RES_VER}]`;
|
|
6513
6532
|
this.#options.logger.error(errorMessage);
|
|
6514
6533
|
throw new Error(errorMessage);
|
|
6515
6534
|
}
|
|
@@ -6527,7 +6546,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6527
6546
|
OPERATION: operation,
|
|
6528
6547
|
RES
|
|
6529
6548
|
}) === void 0) {
|
|
6530
|
-
const errorMessage = `UpdateResource(): Version Conflict. resourceVersionRunResult is undefined. RES_VER: [${RES_VER}]`;
|
|
6549
|
+
const errorMessage = `PGFhirAccessLayer:UpdateResource(): Version Conflict. resourceVersionRunResult is undefined. RES_VER: [${RES_VER}]`;
|
|
6531
6550
|
this.#options.logger.error(errorMessage);
|
|
6532
6551
|
throw new Error(errorMessage);
|
|
6533
6552
|
}
|
|
@@ -6536,7 +6555,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6536
6555
|
return resource;
|
|
6537
6556
|
} catch (error) {
|
|
6538
6557
|
if (useTransaction) await client.query("ROLLBACK");
|
|
6539
|
-
const errorMessage = `UpdateResource(): Error: [${error}]`;
|
|
6558
|
+
const errorMessage = `PGFhirAccessLayer:UpdateResource(): Error: [${error}]`;
|
|
6540
6559
|
this.#options.logger.error(errorMessage);
|
|
6541
6560
|
throw new Error(errorMessage);
|
|
6542
6561
|
} finally {
|
|
@@ -6545,7 +6564,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6545
6564
|
};
|
|
6546
6565
|
DeleteResource = async (resource, RES_VER, transactionHandle) => {
|
|
6547
6566
|
if (!this.#poolManager) {
|
|
6548
|
-
const errorMessage = `DeleteResource(): poolManager not set`;
|
|
6567
|
+
const errorMessage = `PGFhirAccessLayer:DeleteResource(): poolManager not set`;
|
|
6549
6568
|
this.#options.logger.error(errorMessage);
|
|
6550
6569
|
throw new Error(errorMessage);
|
|
6551
6570
|
}
|
|
@@ -6560,7 +6579,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6560
6579
|
useTransaction = true;
|
|
6561
6580
|
}
|
|
6562
6581
|
} catch (error) {
|
|
6563
|
-
const errorMessage = `DeleteResource(): Could not get connection: Error: [${error}]`;
|
|
6582
|
+
const errorMessage = `PGFhirAccessLayer:DeleteResource(): Could not get connection: Error: [${error}]`;
|
|
6564
6583
|
this.#options.logger.error(errorMessage);
|
|
6565
6584
|
throw new Error(errorMessage);
|
|
6566
6585
|
}
|
|
@@ -6577,7 +6596,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6577
6596
|
RES_UPDATED: now
|
|
6578
6597
|
});
|
|
6579
6598
|
if (newVersion === void 0) {
|
|
6580
|
-
const errorMessage = `DeleteResource(): Version Conflict. newVersion is undefined. RES_VER: [${RES_VER}]`;
|
|
6599
|
+
const errorMessage = `PGFhirAccessLayer:DeleteResource(): Version Conflict. newVersion is undefined. RES_VER: [${RES_VER}]`;
|
|
6581
6600
|
this.#options.logger.error(errorMessage);
|
|
6582
6601
|
throw new Error(errorMessage);
|
|
6583
6602
|
}
|
|
@@ -6594,7 +6613,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6594
6613
|
OPERATION: "DELETE",
|
|
6595
6614
|
RES: ""
|
|
6596
6615
|
}) === void 0) {
|
|
6597
|
-
const errorMessage = `DeleteResource(): Version Conflict. resourceVersionRunResult is undefined. RES_VER: [${RES_VER}]`;
|
|
6616
|
+
const errorMessage = `PGFhirAccessLayer:DeleteResource(): Version Conflict. resourceVersionRunResult is undefined. RES_VER: [${RES_VER}]`;
|
|
6598
6617
|
this.#options.logger.error(errorMessage);
|
|
6599
6618
|
throw new Error(errorMessage);
|
|
6600
6619
|
}
|
|
@@ -6603,7 +6622,7 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6603
6622
|
return resource;
|
|
6604
6623
|
} catch (error) {
|
|
6605
6624
|
if (useTransaction) await client.query("ROLLBACK");
|
|
6606
|
-
const errorMessage = `DeleteResource(): Error: [${error}]`;
|
|
6625
|
+
const errorMessage = `PGFhirAccessLayer:DeleteResource(): Error: [${error}]`;
|
|
6607
6626
|
this.#options.logger.error(errorMessage);
|
|
6608
6627
|
throw new Error(errorMessage);
|
|
6609
6628
|
} finally {
|
|
@@ -6612,13 +6631,13 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6612
6631
|
};
|
|
6613
6632
|
ReadResourceRecord = async (RES_TYPE, RES_ID, transactionHandle) => {
|
|
6614
6633
|
if (!this.#poolManager) {
|
|
6615
|
-
const errorMessage = `ReadResourceRecord(): poolManager not set`;
|
|
6634
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecord(): poolManager not set`;
|
|
6616
6635
|
this.#options.logger.error(errorMessage);
|
|
6617
6636
|
throw new Error(errorMessage);
|
|
6618
6637
|
}
|
|
6638
|
+
let client;
|
|
6639
|
+
let useTransaction;
|
|
6619
6640
|
try {
|
|
6620
|
-
let client;
|
|
6621
|
-
let useTransaction;
|
|
6622
6641
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6623
6642
|
client = this.#transactions[transactionHandle].client;
|
|
6624
6643
|
useTransaction = false;
|
|
@@ -6626,39 +6645,43 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6626
6645
|
client = await this.#poolManager.connectReadOnly();
|
|
6627
6646
|
useTransaction = true;
|
|
6628
6647
|
}
|
|
6629
|
-
try {
|
|
6630
|
-
return (await client.query(`
|
|
6631
|
-
SELECT
|
|
6632
|
-
r.*, v.* FROM stsresfhir r
|
|
6633
|
-
JOIN
|
|
6634
|
-
stsresfhirver v
|
|
6635
|
-
ON
|
|
6636
|
-
r.RES_ID = v.RES_ID AND
|
|
6637
|
-
r.RES_TYPE = v.RES_TYPE AND
|
|
6638
|
-
r.RES_VER = v.RES_VER
|
|
6639
|
-
WHERE
|
|
6640
|
-
r.RES_ID = $1 AND
|
|
6641
|
-
r.RES_TYPE = $2 AND
|
|
6642
|
-
r.RES_DELETED_AT IS NULL
|
|
6643
|
-
`, [RES_ID, RES_TYPE])).rows[0];
|
|
6644
|
-
} catch (error) {
|
|
6645
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceRecord(): Query Error: [${error}]`);
|
|
6646
|
-
} finally {
|
|
6647
|
-
if (useTransaction) client.release();
|
|
6648
|
-
}
|
|
6649
6648
|
} catch (error) {
|
|
6650
|
-
|
|
6649
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecord(): Connection Error: [${error}]`;
|
|
6650
|
+
this.#options.logger.error(errorMessage);
|
|
6651
|
+
throw new Error(errorMessage);
|
|
6652
|
+
}
|
|
6653
|
+
try {
|
|
6654
|
+
return (await client.query(`
|
|
6655
|
+
SELECT
|
|
6656
|
+
r.*, v.* FROM stsresfhir r
|
|
6657
|
+
JOIN
|
|
6658
|
+
stsresfhirver v
|
|
6659
|
+
ON
|
|
6660
|
+
r.RES_ID = v.RES_ID AND
|
|
6661
|
+
r.RES_TYPE = v.RES_TYPE AND
|
|
6662
|
+
r.RES_VER = v.RES_VER
|
|
6663
|
+
WHERE
|
|
6664
|
+
r.RES_ID = $1 AND
|
|
6665
|
+
r.RES_TYPE = $2 AND
|
|
6666
|
+
r.RES_DELETED_AT IS NULL
|
|
6667
|
+
`, [RES_ID, RES_TYPE])).rows[0];
|
|
6668
|
+
} catch (error) {
|
|
6669
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecord(): Query Error: [${error}]`;
|
|
6670
|
+
this.#options.logger.error(errorMessage);
|
|
6671
|
+
throw new Error(errorMessage);
|
|
6672
|
+
} finally {
|
|
6673
|
+
if (useTransaction) client.release();
|
|
6651
6674
|
}
|
|
6652
6675
|
};
|
|
6653
6676
|
ReadResourceRecordWithVersion = async (RES_TYPE, RES_ID, RES_VER, transactionHandle) => {
|
|
6654
6677
|
if (!this.#poolManager) {
|
|
6655
|
-
const errorMessage = `ReadResourceRecordWithVersion(): poolManager not set`;
|
|
6678
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecordWithVersion(): poolManager not set`;
|
|
6656
6679
|
this.#options.logger.error(errorMessage);
|
|
6657
6680
|
throw new Error(errorMessage);
|
|
6658
6681
|
}
|
|
6682
|
+
let client;
|
|
6683
|
+
let useTransaction;
|
|
6659
6684
|
try {
|
|
6660
|
-
let client;
|
|
6661
|
-
let useTransaction;
|
|
6662
6685
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6663
6686
|
client = this.#transactions[transactionHandle].client;
|
|
6664
6687
|
useTransaction = false;
|
|
@@ -6666,42 +6689,46 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6666
6689
|
client = await this.#poolManager.connectReadOnly();
|
|
6667
6690
|
useTransaction = true;
|
|
6668
6691
|
}
|
|
6669
|
-
try {
|
|
6670
|
-
return (await client.query(`
|
|
6671
|
-
SELECT
|
|
6672
|
-
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6673
|
-
JOIN
|
|
6674
|
-
stsresfhirver v
|
|
6675
|
-
ON
|
|
6676
|
-
r.RES_ID = v.RES_ID AND
|
|
6677
|
-
r.RES_TYPE = v.RES_TYPE
|
|
6678
|
-
WHERE
|
|
6679
|
-
r.RES_ID = $1 AND
|
|
6680
|
-
r.RES_TYPE = $2 AND
|
|
6681
|
-
v.RES_VER = $3
|
|
6682
|
-
`, [
|
|
6683
|
-
RES_ID,
|
|
6684
|
-
RES_TYPE,
|
|
6685
|
-
RES_VER
|
|
6686
|
-
])).rows[0];
|
|
6687
|
-
} catch (error) {
|
|
6688
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceRecord(): Query Error: [${error}]`);
|
|
6689
|
-
} finally {
|
|
6690
|
-
if (useTransaction) client.release();
|
|
6691
|
-
}
|
|
6692
6692
|
} catch (error) {
|
|
6693
|
-
|
|
6693
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecordWithVersion(): Connection Error: [${error}]`;
|
|
6694
|
+
this.#options.logger.error(errorMessage);
|
|
6695
|
+
throw new Error(errorMessage);
|
|
6696
|
+
}
|
|
6697
|
+
try {
|
|
6698
|
+
return (await client.query(`
|
|
6699
|
+
SELECT
|
|
6700
|
+
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6701
|
+
JOIN
|
|
6702
|
+
stsresfhirver v
|
|
6703
|
+
ON
|
|
6704
|
+
r.RES_ID = v.RES_ID AND
|
|
6705
|
+
r.RES_TYPE = v.RES_TYPE
|
|
6706
|
+
WHERE
|
|
6707
|
+
r.RES_ID = $1 AND
|
|
6708
|
+
r.RES_TYPE = $2 AND
|
|
6709
|
+
v.RES_VER = $3
|
|
6710
|
+
`, [
|
|
6711
|
+
RES_ID,
|
|
6712
|
+
RES_TYPE,
|
|
6713
|
+
RES_VER
|
|
6714
|
+
])).rows[0];
|
|
6715
|
+
} catch (error) {
|
|
6716
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceRecordWithVersion(): Query Error: [${error}]`;
|
|
6717
|
+
this.#options.logger.error(errorMessage);
|
|
6718
|
+
throw new Error(errorMessage);
|
|
6719
|
+
} finally {
|
|
6720
|
+
if (useTransaction) client.release();
|
|
6694
6721
|
}
|
|
6695
6722
|
};
|
|
6696
6723
|
ReadResourceInstanceWithAllVersions = async (RES_TYPE, RES_ID, transactionHandle) => {
|
|
6697
6724
|
if (!this.#poolManager) {
|
|
6698
|
-
const errorMessage = `ReadResourceInstanceWithAllVersions(): poolManager not set`;
|
|
6725
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceInstanceWithAllVersions(): poolManager not set`;
|
|
6699
6726
|
this.#options.logger.error(errorMessage);
|
|
6700
6727
|
throw new Error(errorMessage);
|
|
6701
6728
|
}
|
|
6729
|
+
let client;
|
|
6730
|
+
let useTransaction;
|
|
6702
6731
|
try {
|
|
6703
|
-
let client;
|
|
6704
|
-
let useTransaction;
|
|
6705
6732
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6706
6733
|
client = this.#transactions[transactionHandle].client;
|
|
6707
6734
|
useTransaction = false;
|
|
@@ -6709,39 +6736,43 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6709
6736
|
client = await this.#poolManager.connectReadOnly();
|
|
6710
6737
|
useTransaction = true;
|
|
6711
6738
|
}
|
|
6712
|
-
try {
|
|
6713
|
-
return (await client.query(`
|
|
6714
|
-
SELECT
|
|
6715
|
-
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6716
|
-
JOIN
|
|
6717
|
-
stsresfhirver v
|
|
6718
|
-
ON
|
|
6719
|
-
r.RES_ID = v.RES_ID AND
|
|
6720
|
-
r.RES_TYPE = v.RES_TYPE
|
|
6721
|
-
WHERE
|
|
6722
|
-
r.RES_ID = $1 AND
|
|
6723
|
-
r.RES_TYPE = $2
|
|
6724
|
-
ORDER BY
|
|
6725
|
-
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6726
|
-
`, [RES_ID, RES_TYPE])).rows;
|
|
6727
|
-
} catch (error) {
|
|
6728
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceRecord(): Query Error: [${error}]`);
|
|
6729
|
-
} finally {
|
|
6730
|
-
if (useTransaction) client.release();
|
|
6731
|
-
}
|
|
6732
6739
|
} catch (error) {
|
|
6733
|
-
|
|
6740
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceInstanceWithAllVersions(): Connection Error: [${error}]`;
|
|
6741
|
+
this.#options.logger.error(errorMessage);
|
|
6742
|
+
throw new Error(errorMessage);
|
|
6743
|
+
}
|
|
6744
|
+
try {
|
|
6745
|
+
return (await client.query(`
|
|
6746
|
+
SELECT
|
|
6747
|
+
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6748
|
+
JOIN
|
|
6749
|
+
stsresfhirver v
|
|
6750
|
+
ON
|
|
6751
|
+
r.RES_ID = v.RES_ID AND
|
|
6752
|
+
r.RES_TYPE = v.RES_TYPE
|
|
6753
|
+
WHERE
|
|
6754
|
+
r.RES_ID = $1 AND
|
|
6755
|
+
r.RES_TYPE = $2
|
|
6756
|
+
ORDER BY
|
|
6757
|
+
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6758
|
+
`, [RES_ID, RES_TYPE])).rows;
|
|
6759
|
+
} catch (error) {
|
|
6760
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceInstanceWithAllVersions(): Query Error: [${error}]`;
|
|
6761
|
+
this.#options.logger.error(errorMessage);
|
|
6762
|
+
throw new Error(errorMessage);
|
|
6763
|
+
} finally {
|
|
6764
|
+
if (useTransaction) client.release();
|
|
6734
6765
|
}
|
|
6735
6766
|
};
|
|
6736
6767
|
ReadResourcesWithAllVersions = async (RES_TYPE, transactionHandle) => {
|
|
6737
6768
|
if (!this.#poolManager) {
|
|
6738
|
-
const errorMessage = `ReadResourcesWithAllVersions(): poolManager not set`;
|
|
6769
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourcesWithAllVersions(): poolManager not set`;
|
|
6739
6770
|
this.#options.logger.error(errorMessage);
|
|
6740
6771
|
throw new Error(errorMessage);
|
|
6741
6772
|
}
|
|
6773
|
+
let client;
|
|
6774
|
+
let useTransaction;
|
|
6742
6775
|
try {
|
|
6743
|
-
let client;
|
|
6744
|
-
let useTransaction;
|
|
6745
6776
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6746
6777
|
client = this.#transactions[transactionHandle].client;
|
|
6747
6778
|
useTransaction = false;
|
|
@@ -6749,38 +6780,42 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6749
6780
|
client = await this.#poolManager.connectReadOnly();
|
|
6750
6781
|
useTransaction = true;
|
|
6751
6782
|
}
|
|
6752
|
-
try {
|
|
6753
|
-
return (await client.query(`
|
|
6754
|
-
SELECT
|
|
6755
|
-
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6756
|
-
JOIN
|
|
6757
|
-
stsresfhirver v
|
|
6758
|
-
ON
|
|
6759
|
-
r.RES_ID = v.RES_ID AND
|
|
6760
|
-
r.RES_TYPE = v.RES_TYPE
|
|
6761
|
-
WHERE
|
|
6762
|
-
r.RES_TYPE = $1
|
|
6763
|
-
ORDER BY
|
|
6764
|
-
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6765
|
-
`, [RES_TYPE])).rows;
|
|
6766
|
-
} catch (error) {
|
|
6767
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceRecord(): Query Error: [${error}]`);
|
|
6768
|
-
} finally {
|
|
6769
|
-
if (useTransaction) client.release();
|
|
6770
|
-
}
|
|
6771
6783
|
} catch (error) {
|
|
6772
|
-
|
|
6784
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourcesWithAllVersions(): Connection Error: [${error}]`;
|
|
6785
|
+
this.#options.logger.error(errorMessage);
|
|
6786
|
+
throw new Error(errorMessage);
|
|
6787
|
+
}
|
|
6788
|
+
try {
|
|
6789
|
+
return (await client.query(`
|
|
6790
|
+
SELECT
|
|
6791
|
+
r.*, v.*, r.res_ver as R_res_ver, v.res_ver as V_res_ver FROM stsresfhir r
|
|
6792
|
+
JOIN
|
|
6793
|
+
stsresfhirver v
|
|
6794
|
+
ON
|
|
6795
|
+
r.RES_ID = v.RES_ID AND
|
|
6796
|
+
r.RES_TYPE = v.RES_TYPE
|
|
6797
|
+
WHERE
|
|
6798
|
+
r.RES_TYPE = $1
|
|
6799
|
+
ORDER BY
|
|
6800
|
+
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6801
|
+
`, [RES_TYPE])).rows;
|
|
6802
|
+
} catch (error) {
|
|
6803
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourcesWithAllVersions(): Query Error: [${error}]`;
|
|
6804
|
+
this.#options.logger.error(errorMessage);
|
|
6805
|
+
throw new Error(errorMessage);
|
|
6806
|
+
} finally {
|
|
6807
|
+
if (useTransaction) client.release();
|
|
6773
6808
|
}
|
|
6774
6809
|
};
|
|
6775
6810
|
ReadAllResourcesWithVersions = async (transactionHandle) => {
|
|
6776
6811
|
if (!this.#poolManager) {
|
|
6777
|
-
const errorMessage = `ReadAllResourcesWithVersions(): poolManager not set`;
|
|
6812
|
+
const errorMessage = `PGFhirAccessLayer:ReadAllResourcesWithVersions(): poolManager not set`;
|
|
6778
6813
|
this.#options.logger.error(errorMessage);
|
|
6779
6814
|
throw new Error(errorMessage);
|
|
6780
6815
|
}
|
|
6816
|
+
let client;
|
|
6817
|
+
let useTransaction;
|
|
6781
6818
|
try {
|
|
6782
|
-
let client;
|
|
6783
|
-
let useTransaction;
|
|
6784
6819
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6785
6820
|
client = this.#transactions[transactionHandle].client;
|
|
6786
6821
|
useTransaction = false;
|
|
@@ -6788,25 +6823,29 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6788
6823
|
client = await this.#poolManager.connectReadOnly();
|
|
6789
6824
|
useTransaction = true;
|
|
6790
6825
|
}
|
|
6791
|
-
try {
|
|
6792
|
-
return (await client.query(`
|
|
6793
|
-
SELECT
|
|
6794
|
-
r.*, v.* FROM stsresfhir r
|
|
6795
|
-
JOIN
|
|
6796
|
-
stsresfhirver v
|
|
6797
|
-
ON
|
|
6798
|
-
r.RES_ID = v.RES_ID AND
|
|
6799
|
-
r.RES_TYPE = v.RES_TYPE AND
|
|
6800
|
-
ORDER BY
|
|
6801
|
-
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6802
|
-
`)).rows;
|
|
6803
|
-
} catch (error) {
|
|
6804
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceRecord(): Query Error: [${error}]`);
|
|
6805
|
-
} finally {
|
|
6806
|
-
if (useTransaction) client.release();
|
|
6807
|
-
}
|
|
6808
6826
|
} catch (error) {
|
|
6809
|
-
|
|
6827
|
+
const errorMessage = `PGFhirAccessLayer:ReadAllResourcesWithVersions(): Connection Error: [${error}]`;
|
|
6828
|
+
this.#options.logger.error(errorMessage);
|
|
6829
|
+
throw new Error(errorMessage);
|
|
6830
|
+
}
|
|
6831
|
+
try {
|
|
6832
|
+
return (await client.query(`
|
|
6833
|
+
SELECT
|
|
6834
|
+
r.*, v.* FROM stsresfhir r
|
|
6835
|
+
JOIN
|
|
6836
|
+
stsresfhirver v
|
|
6837
|
+
ON
|
|
6838
|
+
r.RES_ID = v.RES_ID AND
|
|
6839
|
+
r.RES_TYPE = v.RES_TYPE AND
|
|
6840
|
+
ORDER BY
|
|
6841
|
+
v.RES_TYPE ASC, v.RES_ID ASC, v.RES_VER DESC
|
|
6842
|
+
`)).rows;
|
|
6843
|
+
} catch (error) {
|
|
6844
|
+
const errorMessage = `PGFhirAccessLayer:ReadAllResourcesWithVersions(): Query Error: [${error}]`;
|
|
6845
|
+
this.#options.logger.error(errorMessage);
|
|
6846
|
+
throw new Error(errorMessage);
|
|
6847
|
+
} finally {
|
|
6848
|
+
if (useTransaction) client.release();
|
|
6810
6849
|
}
|
|
6811
6850
|
};
|
|
6812
6851
|
ReadAllResourceVersionRecord = () => {
|
|
@@ -6814,23 +6853,23 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6814
6853
|
};
|
|
6815
6854
|
ReadResourceIndexes = async (resource, transactionHandle) => {
|
|
6816
6855
|
if (!this.#poolManager) {
|
|
6817
|
-
const errorMessage = `ReadResourceIndexes(): poolManager not set`;
|
|
6856
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceIndexes(): poolManager not set`;
|
|
6818
6857
|
this.#options.logger.error(errorMessage);
|
|
6819
6858
|
throw new Error(errorMessage);
|
|
6820
6859
|
}
|
|
6860
|
+
let client;
|
|
6861
|
+
let useTransaction;
|
|
6862
|
+
const resultSet = {
|
|
6863
|
+
"stsresfhirlink": [],
|
|
6864
|
+
"stsresfhirstring": [],
|
|
6865
|
+
"stsresfhirtoken": [],
|
|
6866
|
+
"stsresfhirquantity": [],
|
|
6867
|
+
"stsresfhirnumber": [],
|
|
6868
|
+
"stsresfhirdate": [],
|
|
6869
|
+
"stsresfhiruri": [],
|
|
6870
|
+
"stsresfhircombo": []
|
|
6871
|
+
};
|
|
6821
6872
|
try {
|
|
6822
|
-
const resultSet = {
|
|
6823
|
-
"stsresfhirlink": [],
|
|
6824
|
-
"stsresfhirstring": [],
|
|
6825
|
-
"stsresfhirtoken": [],
|
|
6826
|
-
"stsresfhirquantity": [],
|
|
6827
|
-
"stsresfhirnumber": [],
|
|
6828
|
-
"stsresfhirdate": [],
|
|
6829
|
-
"stsresfhiruri": [],
|
|
6830
|
-
"stsresfhircombo": []
|
|
6831
|
-
};
|
|
6832
|
-
let client;
|
|
6833
|
-
let useTransaction;
|
|
6834
6873
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6835
6874
|
client = this.#transactions[transactionHandle].client;
|
|
6836
6875
|
useTransaction = false;
|
|
@@ -6838,34 +6877,38 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6838
6877
|
client = await this.#poolManager.connectReadOnly();
|
|
6839
6878
|
useTransaction = true;
|
|
6840
6879
|
}
|
|
6841
|
-
try {
|
|
6842
|
-
resultSet["stsresfhirlink"] = await this.#dbSTSResourceLink.ReadResourceLinkByResourceIdRecord(client, resource.id, resource.resourceType);
|
|
6843
|
-
resultSet["stsresfhirstring"] = await this.#dbSTSString.ReadByResID(client, resource.id, resource.resourceType);
|
|
6844
|
-
resultSet["stsresfhirtoken"] = await this.#dbSTSToken.ReadByResID(client, resource.id, resource.resourceType);
|
|
6845
|
-
resultSet["stsresfhirquantity"] = await this.#dbSTSQuantity.ReadByResID(client, resource.id, resource.resourceType);
|
|
6846
|
-
resultSet["stsresfhirnumber"] = await this.#dbSTSNumber.ReadByResID(client, resource.id, resource.resourceType);
|
|
6847
|
-
resultSet["stsresfhirdate"] = await this.#dbSTSDate.ReadByResID(client, resource.id, resource.resourceType);
|
|
6848
|
-
resultSet["stsresfhiruri"] = await this.#dbSTSUri.ReadByResID(client, resource.id, resource.resourceType);
|
|
6849
|
-
resultSet["stsresfhircombo"] = await this.#dbSTSCombo.ReadByResID(client, resource.id, resource.resourceType);
|
|
6850
|
-
} catch (error) {
|
|
6851
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ReadResourceIndexes(): Query Error: [${error}]`);
|
|
6852
|
-
} finally {
|
|
6853
|
-
if (useTransaction) client.release();
|
|
6854
|
-
}
|
|
6855
|
-
return resultSet;
|
|
6856
6880
|
} catch (error) {
|
|
6857
|
-
|
|
6881
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceIndexes(): Connection Error: [${error}]`;
|
|
6882
|
+
this.#options.logger.error(errorMessage);
|
|
6883
|
+
throw new Error(errorMessage);
|
|
6884
|
+
}
|
|
6885
|
+
try {
|
|
6886
|
+
resultSet["stsresfhirlink"] = await this.#dbSTSResourceLink.ReadResourceLinkByResourceIdRecord(client, resource.id, resource.resourceType);
|
|
6887
|
+
resultSet["stsresfhirstring"] = await this.#dbSTSString.ReadByResID(client, resource.id, resource.resourceType);
|
|
6888
|
+
resultSet["stsresfhirtoken"] = await this.#dbSTSToken.ReadByResID(client, resource.id, resource.resourceType);
|
|
6889
|
+
resultSet["stsresfhirquantity"] = await this.#dbSTSQuantity.ReadByResID(client, resource.id, resource.resourceType);
|
|
6890
|
+
resultSet["stsresfhirnumber"] = await this.#dbSTSNumber.ReadByResID(client, resource.id, resource.resourceType);
|
|
6891
|
+
resultSet["stsresfhirdate"] = await this.#dbSTSDate.ReadByResID(client, resource.id, resource.resourceType);
|
|
6892
|
+
resultSet["stsresfhiruri"] = await this.#dbSTSUri.ReadByResID(client, resource.id, resource.resourceType);
|
|
6893
|
+
resultSet["stsresfhircombo"] = await this.#dbSTSCombo.ReadByResID(client, resource.id, resource.resourceType);
|
|
6894
|
+
} catch (error) {
|
|
6895
|
+
const errorMessage = `PGFhirAccessLayer:ReadResourceIndexes(): Query Error: [${error}]`;
|
|
6896
|
+
this.#options.logger.error(errorMessage);
|
|
6897
|
+
throw new Error(errorMessage);
|
|
6898
|
+
} finally {
|
|
6899
|
+
if (useTransaction) client.release();
|
|
6858
6900
|
}
|
|
6901
|
+
return resultSet;
|
|
6859
6902
|
};
|
|
6860
6903
|
ExecuteReadQuery = async (queryData, transactionHandle) => {
|
|
6861
6904
|
if (!this.#poolManager) {
|
|
6862
|
-
const errorMessage = `ExecuteReadQuery(): poolManager not set`;
|
|
6905
|
+
const errorMessage = `PGFhirAccessLayer:ExecuteReadQuery(): poolManager not set`;
|
|
6863
6906
|
this.#options.logger.error(errorMessage);
|
|
6864
6907
|
throw new Error(errorMessage);
|
|
6865
6908
|
}
|
|
6909
|
+
let client;
|
|
6910
|
+
let useTransaction;
|
|
6866
6911
|
try {
|
|
6867
|
-
let client;
|
|
6868
|
-
let useTransaction;
|
|
6869
6912
|
if (transactionHandle && this.#transactions[transactionHandle]) {
|
|
6870
6913
|
client = this.#transactions[transactionHandle].client;
|
|
6871
6914
|
useTransaction = false;
|
|
@@ -6873,36 +6916,44 @@ var PGFhirAccessLayer = class extends tiny_emitter.TinyEmitter {
|
|
|
6873
6916
|
client = await this.#poolManager.connectReadOnly();
|
|
6874
6917
|
useTransaction = true;
|
|
6875
6918
|
}
|
|
6876
|
-
try {
|
|
6877
|
-
const { queryText, vals } = queryData;
|
|
6878
|
-
return (await client.query(queryText, vals)).rows;
|
|
6879
|
-
} catch (error) {
|
|
6880
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:ExecuteReadQuery(): Query Error: [${error}]`);
|
|
6881
|
-
} finally {
|
|
6882
|
-
if (useTransaction) client.release();
|
|
6883
|
-
}
|
|
6884
6919
|
} catch (error) {
|
|
6885
|
-
|
|
6920
|
+
const message = `PGFhirAccessLayer:ExecuteReadQuery(): Connection Error: [${error}]`;
|
|
6921
|
+
this.#options.logger.error(message);
|
|
6922
|
+
throw new Error(message);
|
|
6923
|
+
}
|
|
6924
|
+
try {
|
|
6925
|
+
const { queryText, vals } = queryData;
|
|
6926
|
+
return (await client.query(queryText, vals)).rows;
|
|
6927
|
+
} catch (error) {
|
|
6928
|
+
const message = `PGFhirAccessLayer:ExecuteReadQuery(): Query Error: [${error}]`;
|
|
6929
|
+
this.#options.logger.error(message);
|
|
6930
|
+
throw new Error(message);
|
|
6931
|
+
} finally {
|
|
6932
|
+
if (useTransaction) client.release();
|
|
6886
6933
|
}
|
|
6887
6934
|
};
|
|
6888
6935
|
TruncateAll = async () => {
|
|
6889
6936
|
if (!this.#poolManager) {
|
|
6890
|
-
const errorMessage = `TruncateAll(): poolManager not set`;
|
|
6937
|
+
const errorMessage = `PGFhirAccessLayer:TruncateAll(): poolManager not set`;
|
|
6891
6938
|
this.#options.logger.error(errorMessage);
|
|
6892
6939
|
throw new Error(errorMessage);
|
|
6893
6940
|
}
|
|
6941
|
+
let client;
|
|
6894
6942
|
try {
|
|
6895
|
-
let client;
|
|
6896
6943
|
client = await this.#poolManager.connectReadWrite();
|
|
6897
|
-
try {
|
|
6898
|
-
client.query("TRUNCATE TABLE stsresfhir, stsresfhirver, stsresfhirlink, stsresfhirstring, stsresfhirtoken, stsresfhirquantity, stsresfhirnumber, stsresfhiruri, stsresfhirdate, stsresfhircoords, stsresfhircombo");
|
|
6899
|
-
} catch (error) {
|
|
6900
|
-
_nsshunt_stsutils.defaultLogger.error(`DBSTSResource:TruncateAll(): Query Error: [${error}]`);
|
|
6901
|
-
} finally {
|
|
6902
|
-
client.release();
|
|
6903
|
-
}
|
|
6904
6944
|
} catch (error) {
|
|
6905
|
-
|
|
6945
|
+
const message = `PGFhirAccessLayer:TruncateAll(): Connection Error: [${error}]`;
|
|
6946
|
+
this.#options.logger.error(message);
|
|
6947
|
+
throw new Error(message);
|
|
6948
|
+
}
|
|
6949
|
+
try {
|
|
6950
|
+
client.query("TRUNCATE TABLE stsresfhir, stsresfhirver, stsresfhirlink, stsresfhirstring, stsresfhirtoken, stsresfhirquantity, stsresfhirnumber, stsresfhiruri, stsresfhirdate, stsresfhircoords, stsresfhircombo");
|
|
6951
|
+
} catch (error) {
|
|
6952
|
+
const message = `PGFhirAccessLayer:TruncateAll(): Query Error: [${error}]`;
|
|
6953
|
+
this.#options.logger.error(message);
|
|
6954
|
+
throw new Error(message);
|
|
6955
|
+
} finally {
|
|
6956
|
+
client.release();
|
|
6906
6957
|
}
|
|
6907
6958
|
};
|
|
6908
6959
|
};
|