@veritas-lex/contract-analysis-package 1.2.3
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/README.md +181 -0
- package/dist/auth/auth-core.module.d.ts +21 -0
- package/dist/auth/auth-core.module.d.ts.map +1 -0
- package/dist/auth/auth-core.module.js +56 -0
- package/dist/auth/auth-core.module.js.map +1 -0
- package/dist/auth/decorators/current-user.decorator.d.ts +2 -0
- package/dist/auth/decorators/current-user.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/current-user.decorator.js +9 -0
- package/dist/auth/decorators/current-user.decorator.js.map +1 -0
- package/dist/auth/decorators/public.decorator.d.ts +3 -0
- package/dist/auth/decorators/public.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/public.decorator.js +8 -0
- package/dist/auth/decorators/public.decorator.js.map +1 -0
- package/dist/auth/guards/jwt-auth.guard.d.ts +11 -0
- package/dist/auth/guards/jwt-auth.guard.d.ts.map +1 -0
- package/dist/auth/guards/jwt-auth.guard.js +39 -0
- package/dist/auth/guards/jwt-auth.guard.js.map +1 -0
- package/dist/auth/index.d.ts +7 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +15 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/interfaces/jwt-payload.interface.d.ts +24 -0
- package/dist/auth/interfaces/jwt-payload.interface.d.ts.map +1 -0
- package/dist/auth/interfaces/jwt-payload.interface.js +3 -0
- package/dist/auth/interfaces/jwt-payload.interface.js.map +1 -0
- package/dist/auth/strategies/base-jwt.strategy.d.ts +47 -0
- package/dist/auth/strategies/base-jwt.strategy.d.ts.map +1 -0
- package/dist/auth/strategies/base-jwt.strategy.js +162 -0
- package/dist/auth/strategies/base-jwt.strategy.js.map +1 -0
- package/dist/bootstrap/configure-app.d.ts +50 -0
- package/dist/bootstrap/configure-app.d.ts.map +1 -0
- package/dist/bootstrap/configure-app.js +117 -0
- package/dist/bootstrap/configure-app.js.map +1 -0
- package/dist/bootstrap/index.d.ts +3 -0
- package/dist/bootstrap/index.d.ts.map +1 -0
- package/dist/bootstrap/index.js +6 -0
- package/dist/bootstrap/index.js.map +1 -0
- package/dist/config/app.config.d.ts +37 -0
- package/dist/config/app.config.d.ts.map +1 -0
- package/dist/config/app.config.js +28 -0
- package/dist/config/app.config.js.map +1 -0
- package/dist/config/database.config.d.ts +48 -0
- package/dist/config/database.config.d.ts.map +1 -0
- package/dist/config/database.config.js +34 -0
- package/dist/config/database.config.js.map +1 -0
- package/dist/config/doc.config.d.ts +31 -0
- package/dist/config/doc.config.d.ts.map +1 -0
- package/dist/config/doc.config.js +22 -0
- package/dist/config/doc.config.js.map +1 -0
- package/dist/config/index.d.ts +17 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +26 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/jwt.config.d.ts +19 -0
- package/dist/config/jwt.config.d.ts.map +1 -0
- package/dist/config/jwt.config.js +28 -0
- package/dist/config/jwt.config.js.map +1 -0
- package/dist/config/logging.config.d.ts +33 -0
- package/dist/config/logging.config.d.ts.map +1 -0
- package/dist/config/logging.config.js +106 -0
- package/dist/config/logging.config.js.map +1 -0
- package/dist/config/redis.config.d.ts +19 -0
- package/dist/config/redis.config.d.ts.map +1 -0
- package/dist/config/redis.config.js +16 -0
- package/dist/config/redis.config.js.map +1 -0
- package/dist/config/security.config.d.ts +66 -0
- package/dist/config/security.config.d.ts.map +1 -0
- package/dist/config/security.config.js +66 -0
- package/dist/config/security.config.js.map +1 -0
- package/dist/config/storage.config.d.ts +20 -0
- package/dist/config/storage.config.d.ts.map +1 -0
- package/dist/config/storage.config.js +17 -0
- package/dist/config/storage.config.js.map +1 -0
- package/dist/config/validation.config.d.ts +62 -0
- package/dist/config/validation.config.d.ts.map +1 -0
- package/dist/config/validation.config.js +139 -0
- package/dist/config/validation.config.js.map +1 -0
- package/dist/constants/enums.d.ts +76 -0
- package/dist/constants/enums.d.ts.map +1 -0
- package/dist/constants/enums.js +92 -0
- package/dist/constants/enums.js.map +1 -0
- package/dist/constants/file-validation.constants.d.ts +28 -0
- package/dist/constants/file-validation.constants.d.ts.map +1 -0
- package/dist/constants/file-validation.constants.js +81 -0
- package/dist/constants/file-validation.constants.js.map +1 -0
- package/dist/constants/index.d.ts +6 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +26 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/constants/pii-classifications.constants.d.ts +27 -0
- package/dist/constants/pii-classifications.constants.d.ts.map +1 -0
- package/dist/constants/pii-classifications.constants.js +68 -0
- package/dist/constants/pii-classifications.constants.js.map +1 -0
- package/dist/database/base.entity.d.ts +6 -0
- package/dist/database/base.entity.d.ts.map +1 -0
- package/dist/database/base.entity.js +32 -0
- package/dist/database/base.entity.js.map +1 -0
- package/dist/database/database.module.d.ts +32 -0
- package/dist/database/database.module.d.ts.map +1 -0
- package/dist/database/database.module.js +69 -0
- package/dist/database/database.module.js.map +1 -0
- package/dist/database/entities/base-audit-log.entity.d.ts +21 -0
- package/dist/database/entities/base-audit-log.entity.d.ts.map +1 -0
- package/dist/database/entities/base-audit-log.entity.js +90 -0
- package/dist/database/entities/base-audit-log.entity.js.map +1 -0
- package/dist/database/entities/base-contract-chunk.entity.d.ts +18 -0
- package/dist/database/entities/base-contract-chunk.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-chunk.entity.js +71 -0
- package/dist/database/entities/base-contract-chunk.entity.js.map +1 -0
- package/dist/database/entities/base-contract-event.entity.d.ts +16 -0
- package/dist/database/entities/base-contract-event.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-event.entity.js +66 -0
- package/dist/database/entities/base-contract-event.entity.js.map +1 -0
- package/dist/database/entities/base-contract-key-date-rule.entity.d.ts +31 -0
- package/dist/database/entities/base-contract-key-date-rule.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-key-date-rule.entity.js +140 -0
- package/dist/database/entities/base-contract-key-date-rule.entity.js.map +1 -0
- package/dist/database/entities/base-contract-pii-replacement.entity.d.ts +18 -0
- package/dist/database/entities/base-contract-pii-replacement.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-pii-replacement.entity.js +67 -0
- package/dist/database/entities/base-contract-pii-replacement.entity.js.map +1 -0
- package/dist/database/entities/base-contract-red-flag.entity.d.ts +27 -0
- package/dist/database/entities/base-contract-red-flag.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-red-flag.entity.js +114 -0
- package/dist/database/entities/base-contract-red-flag.entity.js.map +1 -0
- package/dist/database/entities/base-contract-task.entity.d.ts +20 -0
- package/dist/database/entities/base-contract-task.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-task.entity.js +87 -0
- package/dist/database/entities/base-contract-task.entity.js.map +1 -0
- package/dist/database/entities/base-contract-text.entity.d.ts +19 -0
- package/dist/database/entities/base-contract-text.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract-text.entity.js +77 -0
- package/dist/database/entities/base-contract-text.entity.js.map +1 -0
- package/dist/database/entities/base-contract.entity.d.ts +56 -0
- package/dist/database/entities/base-contract.entity.d.ts.map +1 -0
- package/dist/database/entities/base-contract.entity.js +221 -0
- package/dist/database/entities/base-contract.entity.js.map +1 -0
- package/dist/database/entities/base-job.entity.d.ts +21 -0
- package/dist/database/entities/base-job.entity.d.ts.map +1 -0
- package/dist/database/entities/base-job.entity.js +89 -0
- package/dist/database/entities/base-job.entity.js.map +1 -0
- package/dist/database/entities/base-qna-question.entity.d.ts +22 -0
- package/dist/database/entities/base-qna-question.entity.d.ts.map +1 -0
- package/dist/database/entities/base-qna-question.entity.js +92 -0
- package/dist/database/entities/base-qna-question.entity.js.map +1 -0
- package/dist/database/entities/base-scoring-criteria.entity.d.ts +57 -0
- package/dist/database/entities/base-scoring-criteria.entity.d.ts.map +1 -0
- package/dist/database/entities/base-scoring-criteria.entity.js +376 -0
- package/dist/database/entities/base-scoring-criteria.entity.js.map +1 -0
- package/dist/database/entities/base-users-profile.entity.d.ts +32 -0
- package/dist/database/entities/base-users-profile.entity.d.ts.map +1 -0
- package/dist/database/entities/base-users-profile.entity.js +91 -0
- package/dist/database/entities/base-users-profile.entity.js.map +1 -0
- package/dist/database/entities/index.d.ts +16 -0
- package/dist/database/entities/index.d.ts.map +1 -0
- package/dist/database/entities/index.js +37 -0
- package/dist/database/entities/index.js.map +1 -0
- package/dist/database/entities/qna-question-template.entity.d.ts +30 -0
- package/dist/database/entities/qna-question-template.entity.d.ts.map +1 -0
- package/dist/database/entities/qna-question-template.entity.js +145 -0
- package/dist/database/entities/qna-question-template.entity.js.map +1 -0
- package/dist/database/entities/qna-response.entity.d.ts +29 -0
- package/dist/database/entities/qna-response.entity.d.ts.map +1 -0
- package/dist/database/entities/qna-response.entity.js +129 -0
- package/dist/database/entities/qna-response.entity.js.map +1 -0
- package/dist/database/index.d.ts +7 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +32 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/redis.module.d.ts +12 -0
- package/dist/database/redis.module.d.ts.map +1 -0
- package/dist/database/redis.module.js +40 -0
- package/dist/database/redis.module.js.map +1 -0
- package/dist/database/redis.provider.d.ts +15 -0
- package/dist/database/redis.provider.d.ts.map +1 -0
- package/dist/database/redis.provider.js +42 -0
- package/dist/database/redis.provider.js.map +1 -0
- package/dist/dto/api-response.dto.d.ts +36 -0
- package/dist/dto/api-response.dto.d.ts.map +1 -0
- package/dist/dto/api-response.dto.js +88 -0
- package/dist/dto/api-response.dto.js.map +1 -0
- package/dist/dto/index.d.ts +2 -0
- package/dist/dto/index.d.ts.map +1 -0
- package/dist/dto/index.js +6 -0
- package/dist/dto/index.js.map +1 -0
- package/dist/filters/all-exceptions.filter.d.ts +43 -0
- package/dist/filters/all-exceptions.filter.d.ts.map +1 -0
- package/dist/filters/all-exceptions.filter.js +123 -0
- package/dist/filters/all-exceptions.filter.js.map +1 -0
- package/dist/filters/index.d.ts +3 -0
- package/dist/filters/index.d.ts.map +1 -0
- package/dist/filters/index.js +6 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/helpers/crypto.service.d.ts +53 -0
- package/dist/helpers/crypto.service.d.ts.map +1 -0
- package/dist/helpers/crypto.service.js +153 -0
- package/dist/helpers/crypto.service.js.map +1 -0
- package/dist/helpers/index.d.ts +2 -0
- package/dist/helpers/index.d.ts.map +1 -0
- package/dist/helpers/index.js +6 -0
- package/dist/helpers/index.js.map +1 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +86 -0
- package/dist/index.js.map +1 -0
- package/dist/swagger/index.d.ts +2 -0
- package/dist/swagger/index.d.ts.map +1 -0
- package/dist/swagger/index.js +6 -0
- package/dist/swagger/index.js.map +1 -0
- package/dist/swagger/swagger.d.ts +16 -0
- package/dist/swagger/swagger.d.ts.map +1 -0
- package/dist/swagger/swagger.js +59 -0
- package/dist/swagger/swagger.js.map +1 -0
- package/package.json +63 -0
|
@@ -0,0 +1,59 @@
|
|
|
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.SwaggerDocs = void 0;
|
|
7
|
+
const common_1 = require("@nestjs/common");
|
|
8
|
+
const config_1 = require("@nestjs/config");
|
|
9
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
10
|
+
const express_basic_auth_1 = __importDefault(require("express-basic-auth"));
|
|
11
|
+
const swagger_themes_1 = require("swagger-themes");
|
|
12
|
+
/**
|
|
13
|
+
* Swagger/OpenAPI Documentation Setup
|
|
14
|
+
*
|
|
15
|
+
* Reads configuration from the `'doc'` config namespace:
|
|
16
|
+
* - `doc.name` — API title
|
|
17
|
+
* - `doc.description` — API description
|
|
18
|
+
* - `doc.version` — API version
|
|
19
|
+
* - `doc.prefix` — URL prefix (default `/docs`)
|
|
20
|
+
* - `doc.auth.username` / `doc.auth.password` — basic-auth credentials
|
|
21
|
+
*
|
|
22
|
+
* Protected with HTTP basic authentication.
|
|
23
|
+
* Uses the DARK swagger theme.
|
|
24
|
+
*/
|
|
25
|
+
const SwaggerDocs = (app) => {
|
|
26
|
+
const configService = app.get(config_1.ConfigService);
|
|
27
|
+
const logger = new common_1.Logger();
|
|
28
|
+
const theme = new swagger_themes_1.SwaggerTheme();
|
|
29
|
+
const docName = configService.get("doc.name", "API Specification");
|
|
30
|
+
const docDesc = configService.get("doc.description", "API Documentation");
|
|
31
|
+
const docVersion = configService.get("doc.version", "1.0");
|
|
32
|
+
const docPrefix = configService.get("doc.prefix", "/docs");
|
|
33
|
+
const swaggerUser = configService.get("doc.auth.username", "admin");
|
|
34
|
+
const swaggerPassword = configService.get("doc.auth.password", "admin");
|
|
35
|
+
const documentBuild = new swagger_1.DocumentBuilder()
|
|
36
|
+
.setTitle(docName)
|
|
37
|
+
.setDescription(docDesc)
|
|
38
|
+
.setVersion(docVersion)
|
|
39
|
+
.addBearerAuth()
|
|
40
|
+
.build();
|
|
41
|
+
app.use(["/docs", "/docs-json", "/docs-yaml"], (0, express_basic_auth_1.default)({
|
|
42
|
+
challenge: true,
|
|
43
|
+
users: {
|
|
44
|
+
[swaggerUser]: swaggerPassword,
|
|
45
|
+
},
|
|
46
|
+
}));
|
|
47
|
+
const options = {
|
|
48
|
+
explorer: true,
|
|
49
|
+
customCss: theme.getBuffer(swagger_themes_1.SwaggerThemeNameEnum.DARK),
|
|
50
|
+
customSiteTitle: docName,
|
|
51
|
+
};
|
|
52
|
+
const document = swagger_1.SwaggerModule.createDocument(app, documentBuild);
|
|
53
|
+
swagger_1.SwaggerModule.setup(docPrefix, app, document, options);
|
|
54
|
+
logger.log(`==========================================================`);
|
|
55
|
+
logger.log(`Docs will serve on ${docPrefix}`, "MainDocs");
|
|
56
|
+
logger.log(`==========================================================`);
|
|
57
|
+
};
|
|
58
|
+
exports.SwaggerDocs = SwaggerDocs;
|
|
59
|
+
//# sourceMappingURL=swagger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"swagger.js","sourceRoot":"","sources":["../../src/swagger/swagger.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAwC;AACxC,2CAA+C;AAE/C,6CAAiE;AACjE,4EAA2C;AAC3C,mDAAoE;AAEpE;;;;;;;;;;;;GAYG;AACI,MAAM,WAAW,GAAG,CAAC,GAAoB,EAAQ,EAAE;IACxD,MAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,sBAAa,CAAC,CAAC;IAC7C,MAAM,MAAM,GAAG,IAAI,eAAM,EAAE,CAAC;IAC5B,MAAM,KAAK,GAAG,IAAI,6BAAY,EAAE,CAAC;IAEjC,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAS,UAAU,EAAE,mBAAmB,CAAC,CAAC;IAC3E,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAC/B,iBAAiB,EACjB,mBAAmB,CACpB,CAAC;IACF,MAAM,UAAU,GAAG,aAAa,CAAC,GAAG,CAAS,aAAa,EAAE,KAAK,CAAC,CAAC;IACnE,MAAM,SAAS,GAAG,aAAa,CAAC,GAAG,CAAS,YAAY,EAAE,OAAO,CAAC,CAAC;IACnE,MAAM,WAAW,GAAG,aAAa,CAAC,GAAG,CAAS,mBAAmB,EAAE,OAAO,CAAC,CAAC;IAC5E,MAAM,eAAe,GAAG,aAAa,CAAC,GAAG,CACvC,mBAAmB,EACnB,OAAO,CACR,CAAC;IAEF,MAAM,aAAa,GAAG,IAAI,yBAAe,EAAE;SACxC,QAAQ,CAAC,OAAO,CAAC;SACjB,cAAc,CAAC,OAAO,CAAC;SACvB,UAAU,CAAC,UAAU,CAAC;SACtB,aAAa,EAAE;SACf,KAAK,EAAE,CAAC;IAEX,GAAG,CAAC,GAAG,CACL,CAAC,OAAO,EAAE,YAAY,EAAE,YAAY,CAAC,EACrC,IAAA,4BAAS,EAAC;QACR,SAAS,EAAE,IAAI;QACf,KAAK,EAAE;YACL,CAAC,WAAW,CAAC,EAAE,eAAe;SAC/B;KACF,CAAC,CACH,CAAC;IAEF,MAAM,OAAO,GAAG;QACd,QAAQ,EAAE,IAAI;QACd,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,qCAAoB,CAAC,IAAI,CAAC;QACrD,eAAe,EAAE,OAAO;KACzB,CAAC;IAEF,MAAM,QAAQ,GAAG,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;IAClE,uBAAa,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAEvD,MAAM,CAAC,GAAG,CAAC,4DAA4D,CAAC,CAAC;IACzE,MAAM,CAAC,GAAG,CAAC,sBAAsB,SAAS,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1D,MAAM,CAAC,GAAG,CAAC,4DAA4D,CAAC,CAAC;AAC3E,CAAC,CAAC;AA/CW,QAAA,WAAW,eA+CtB"}
|
package/package.json
ADDED
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@veritas-lex/contract-analysis-package",
|
|
3
|
+
"version": "1.2.3",
|
|
4
|
+
"description": "Shared NestJS infrastructure for Contract Analysis APIs",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc -p tsconfig.build.json",
|
|
9
|
+
"clean": "rimraf dist tsconfig.build.tsbuildinfo",
|
|
10
|
+
"prepublishOnly": "npm run clean && npm run build"
|
|
11
|
+
},
|
|
12
|
+
"peerDependencies": {
|
|
13
|
+
"@nestjs/bullmq": "^11.0.4",
|
|
14
|
+
"@nestjs/common": "^11.1.13",
|
|
15
|
+
"@nestjs/config": "^4.0.3",
|
|
16
|
+
"@nestjs/core": "^11.1.13",
|
|
17
|
+
"@nestjs/jwt": "^11.0.2",
|
|
18
|
+
"@nestjs/passport": "^11.0.5",
|
|
19
|
+
"@nestjs/platform-express": "^11.1.13",
|
|
20
|
+
"@nestjs/swagger": "^11.2.6",
|
|
21
|
+
"@nestjs/typeorm": "^11.0.0",
|
|
22
|
+
"bullmq": "^5.67.3",
|
|
23
|
+
"class-transformer": "^0.5.1",
|
|
24
|
+
"class-validator": "^0.14.3",
|
|
25
|
+
"compression": "^1.8.1",
|
|
26
|
+
"express-basic-auth": "^1.2.1",
|
|
27
|
+
"helmet": "^8.1.0",
|
|
28
|
+
"joi": "^18.0.2",
|
|
29
|
+
"jsonwebtoken": "^9.0.3",
|
|
30
|
+
"jwks-rsa": "^3.2.2",
|
|
31
|
+
"nestjs-pino": "^4.5.0",
|
|
32
|
+
"passport": "^0.7.0",
|
|
33
|
+
"passport-jwt": "^4.0.1",
|
|
34
|
+
"reflect-metadata": "^0.2.2",
|
|
35
|
+
"rxjs": "^7.8.2",
|
|
36
|
+
"swagger-themes": "^1.4.3",
|
|
37
|
+
"typeorm": "^0.3.28"
|
|
38
|
+
},
|
|
39
|
+
"devDependencies": {
|
|
40
|
+
"@types/compression": "^1.8.1",
|
|
41
|
+
"@types/express": "^5.0.6",
|
|
42
|
+
"@types/joi": "^17.2.2",
|
|
43
|
+
"@types/jsonwebtoken": "^9.0.10",
|
|
44
|
+
"@types/node": "^25.2.3",
|
|
45
|
+
"@types/passport-jwt": "^4.0.1",
|
|
46
|
+
"rimraf": "^6.1.2",
|
|
47
|
+
"typescript": "^5.9.3"
|
|
48
|
+
},
|
|
49
|
+
"files": [
|
|
50
|
+
"dist"
|
|
51
|
+
],
|
|
52
|
+
"engines": {
|
|
53
|
+
"node": ">= 24"
|
|
54
|
+
},
|
|
55
|
+
"repository": {
|
|
56
|
+
"type": "git",
|
|
57
|
+
"url": "https://github.com/IgnatG/contract-analysis-package.git"
|
|
58
|
+
},
|
|
59
|
+
"publishConfig": {
|
|
60
|
+
"access": "public"
|
|
61
|
+
},
|
|
62
|
+
"license": "GPL 3.0"
|
|
63
|
+
}
|