@rafikidota/cuba-ofertas-scraping 0.30.0 → 0.32.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/dist/common/class/image.d.ts +9 -0
- package/dist/common/class/image.js +16 -0
- package/dist/common/class/image.js.map +1 -0
- package/dist/common/enum/event.enum.d.ts +1 -0
- package/dist/common/enum/event.enum.js +1 -0
- package/dist/common/enum/event.enum.js.map +1 -1
- package/dist/common/enum/shop-slug.enum.d.ts +11 -0
- package/dist/common/enum/shop-slug.enum.js +16 -0
- package/dist/common/enum/shop-slug.enum.js.map +1 -0
- package/dist/common/index.d.ts +3 -0
- package/dist/common/index.js +3 -0
- package/dist/common/index.js.map +1 -1
- package/dist/common/interface/image.interface.d.ts +5 -0
- package/dist/common/interface/image.interface.js +3 -0
- package/dist/common/interface/image.interface.js.map +1 -0
- package/dist/modules/health/dto/health.dto.d.ts +4 -0
- package/dist/modules/health/dto/health.dto.js +22 -0
- package/dist/modules/health/dto/health.dto.js.map +1 -0
- package/dist/modules/health/enum/health-status.d.ts +4 -0
- package/dist/modules/health/enum/health-status.js +9 -0
- package/dist/modules/health/enum/health-status.js.map +1 -0
- package/dist/modules/health/health.controller.d.ts +14 -0
- package/dist/modules/health/health.controller.js +45 -0
- package/dist/modules/health/health.controller.js.map +1 -0
- package/dist/modules/health/health.module.d.ts +2 -0
- package/dist/modules/health/health.module.js +24 -0
- package/dist/modules/health/health.module.js.map +1 -0
- package/dist/modules/health/health.service.d.ts +18 -0
- package/dist/modules/health/health.service.js +81 -0
- package/dist/modules/health/health.service.js.map +1 -0
- package/dist/modules/index.d.ts +1 -0
- package/dist/modules/index.js +1 -0
- package/dist/modules/index.js.map +1 -1
- package/dist/modules/repository/repository.module.js +2 -0
- package/dist/modules/repository/repository.module.js.map +1 -1
- package/dist/modules/repository/repository.service.d.ts +14 -9
- package/dist/modules/repository/repository.service.js +37 -21
- package/dist/modules/repository/repository.service.js.map +1 -1
- package/dist/modules/repository/services/category.repository.service.d.ts +3 -3
- package/dist/modules/repository/services/category.repository.service.js +8 -8
- package/dist/modules/repository/services/category.repository.service.js.map +1 -1
- package/dist/modules/repository/services/image.repository.service.d.ts +9 -0
- package/dist/modules/repository/services/image.repository.service.js +45 -0
- package/dist/modules/repository/services/image.repository.service.js.map +1 -0
- package/dist/modules/repository/services/product.repository.service.d.ts +3 -3
- package/dist/modules/repository/services/product.repository.service.js +9 -9
- package/dist/modules/repository/services/product.repository.service.js.map +1 -1
- package/dist/modules/repository/services/provider.repository.service.d.ts +3 -3
- package/dist/modules/repository/services/provider.repository.service.js +8 -8
- package/dist/modules/repository/services/provider.repository.service.js.map +1 -1
- package/dist/modules/repository/services/province.repository.service.d.ts +3 -3
- package/dist/modules/repository/services/province.repository.service.js +8 -8
- package/dist/modules/repository/services/province.repository.service.js.map +1 -1
- package/package.json +14 -11
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Image = void 0;
|
|
4
|
+
class Image {
|
|
5
|
+
constructor(data) {
|
|
6
|
+
Object.assign(this, data);
|
|
7
|
+
}
|
|
8
|
+
update(data) {
|
|
9
|
+
Object.assign(this, data);
|
|
10
|
+
}
|
|
11
|
+
getData() {
|
|
12
|
+
return this;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.Image = Image;
|
|
16
|
+
//# sourceMappingURL=image.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.js","sourceRoot":"","sources":["../../../src/common/class/image.ts"],"names":[],"mappings":";;;AAEA,MAAa,KAAK;IAKhB,YAAY,IAAY;QACtB,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,IAAqB;QAC1B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO;QACL,OAAO,IAAyB,CAAC;IACnC,CAAC;CACF;AAhBD,sBAgBC"}
|
|
@@ -4,6 +4,7 @@ exports.ScrapingEvent = void 0;
|
|
|
4
4
|
var ScrapingEvent;
|
|
5
5
|
(function (ScrapingEvent) {
|
|
6
6
|
ScrapingEvent["SAVE_PROVINCES"] = "save.provinces";
|
|
7
|
+
ScrapingEvent["SAVE_IMAGES"] = "save.images";
|
|
7
8
|
ScrapingEvent["SAVE_CATEGORIES"] = "save.categories";
|
|
8
9
|
ScrapingEvent["SAVE_PRODUCTS"] = "save.products";
|
|
9
10
|
ScrapingEvent["SAVE_PROVIDERS"] = "save.providers";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.enum.js","sourceRoot":"","sources":["../../../src/common/enum/event.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,
|
|
1
|
+
{"version":3,"file":"event.enum.js","sourceRoot":"","sources":["../../../src/common/enum/event.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,aAQX;AARD,WAAY,aAAa;IACvB,kDAAiC,CAAA;IACjC,4CAA2B,CAAA;IAC3B,oDAAmC,CAAA;IACnC,gDAA+B,CAAA;IAC/B,kDAAiC,CAAA;IACjC,gCAAe,CAAA;IACf,0DAAyC,CAAA;AAC3C,CAAC,EARW,aAAa,6BAAb,aAAa,QAQxB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare enum ShopSlugEnum {
|
|
2
|
+
SUPERMARKET23 = "sm23",
|
|
3
|
+
KATAPULK = "kata",
|
|
4
|
+
TUAMBIA = "tuambia",
|
|
5
|
+
ALAWAO = "alawao",
|
|
6
|
+
CUBALLAMA = "cuballama",
|
|
7
|
+
DIMECUBA = "dimecuba",
|
|
8
|
+
LAJABALINA = "jabalina",
|
|
9
|
+
MIHOGAR53 = "mh53",
|
|
10
|
+
MALLHABANA = "mallhabana"
|
|
11
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ShopSlugEnum = void 0;
|
|
4
|
+
var ShopSlugEnum;
|
|
5
|
+
(function (ShopSlugEnum) {
|
|
6
|
+
ShopSlugEnum["SUPERMARKET23"] = "sm23";
|
|
7
|
+
ShopSlugEnum["KATAPULK"] = "kata";
|
|
8
|
+
ShopSlugEnum["TUAMBIA"] = "tuambia";
|
|
9
|
+
ShopSlugEnum["ALAWAO"] = "alawao";
|
|
10
|
+
ShopSlugEnum["CUBALLAMA"] = "cuballama";
|
|
11
|
+
ShopSlugEnum["DIMECUBA"] = "dimecuba";
|
|
12
|
+
ShopSlugEnum["LAJABALINA"] = "jabalina";
|
|
13
|
+
ShopSlugEnum["MIHOGAR53"] = "mh53";
|
|
14
|
+
ShopSlugEnum["MALLHABANA"] = "mallhabana";
|
|
15
|
+
})(ShopSlugEnum || (exports.ShopSlugEnum = ShopSlugEnum = {}));
|
|
16
|
+
//# sourceMappingURL=shop-slug.enum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shop-slug.enum.js","sourceRoot":"","sources":["../../../src/common/enum/shop-slug.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,YAUX;AAVD,WAAY,YAAY;IACtB,sCAAsB,CAAA;IACtB,iCAAiB,CAAA;IACjB,mCAAmB,CAAA;IACnB,iCAAiB,CAAA;IACjB,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;IACrB,uCAAuB,CAAA;IACvB,kCAAkB,CAAA;IAClB,yCAAyB,CAAA;AAC3B,CAAC,EAVW,YAAY,4BAAZ,YAAY,QAUvB"}
|
package/dist/common/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './class/category';
|
|
2
|
+
export * from './class/image';
|
|
2
3
|
export * from './class/cookie';
|
|
3
4
|
export * from './class/municipality';
|
|
4
5
|
export * from './class/product';
|
|
@@ -19,9 +20,11 @@ export * from './enum/scraping-label.enum';
|
|
|
19
20
|
export * from './enum/scraping-message-pattern.enum';
|
|
20
21
|
export * from './enum/scraping-result-status.enum';
|
|
21
22
|
export * from './enum/scraping-type.enum';
|
|
23
|
+
export * from './enum/shop-slug.enum';
|
|
22
24
|
export * from './env/scraper.env.config';
|
|
23
25
|
export * from './env/scraper.env.validation';
|
|
24
26
|
export * from './interface/category.interface';
|
|
27
|
+
export * from './interface/image.interface';
|
|
25
28
|
export * from './interface/cookie.interface';
|
|
26
29
|
export * from './interface/municipality.interface';
|
|
27
30
|
export * from './interface/product.interface';
|
package/dist/common/index.js
CHANGED
|
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./class/category"), exports);
|
|
18
|
+
__exportStar(require("./class/image"), exports);
|
|
18
19
|
__exportStar(require("./class/cookie"), exports);
|
|
19
20
|
__exportStar(require("./class/municipality"), exports);
|
|
20
21
|
__exportStar(require("./class/product"), exports);
|
|
@@ -35,9 +36,11 @@ __exportStar(require("./enum/scraping-label.enum"), exports);
|
|
|
35
36
|
__exportStar(require("./enum/scraping-message-pattern.enum"), exports);
|
|
36
37
|
__exportStar(require("./enum/scraping-result-status.enum"), exports);
|
|
37
38
|
__exportStar(require("./enum/scraping-type.enum"), exports);
|
|
39
|
+
__exportStar(require("./enum/shop-slug.enum"), exports);
|
|
38
40
|
__exportStar(require("./env/scraper.env.config"), exports);
|
|
39
41
|
__exportStar(require("./env/scraper.env.validation"), exports);
|
|
40
42
|
__exportStar(require("./interface/category.interface"), exports);
|
|
43
|
+
__exportStar(require("./interface/image.interface"), exports);
|
|
41
44
|
__exportStar(require("./interface/cookie.interface"), exports);
|
|
42
45
|
__exportStar(require("./interface/municipality.interface"), exports);
|
|
43
46
|
__exportStar(require("./interface/product.interface"), exports);
|
package/dist/common/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,iDAA+B;AAC/B,uDAAqC;AACrC,kDAAgC;AAChC,mDAAiC;AACjC,mDAAiC;AACjC,yDAAuC;AACvC,qEAAmD;AACnD,0DAAwC;AAExC,4DAA0C;AAC1C,oDAAkC;AAClC,sDAAoC;AACpC,qDAAmC;AACnC,kDAAgC;AAEhC,oDAAkC;AAClC,sDAAoC;AACpC,2DAAyC;AACzC,6DAA2C;AAC3C,uEAAqD;AACrD,qEAAmD;AACnD,4DAA0C;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,gDAA8B;AAC9B,iDAA+B;AAC/B,uDAAqC;AACrC,kDAAgC;AAChC,mDAAiC;AACjC,mDAAiC;AACjC,yDAAuC;AACvC,qEAAmD;AACnD,0DAAwC;AAExC,4DAA0C;AAC1C,oDAAkC;AAClC,sDAAoC;AACpC,qDAAmC;AACnC,kDAAgC;AAEhC,oDAAkC;AAClC,sDAAoC;AACpC,2DAAyC;AACzC,6DAA2C;AAC3C,uEAAqD;AACrD,qEAAmD;AACnD,4DAA0C;AAC1C,wDAAsC;AAEtC,2DAAyC;AACzC,+DAA6C;AAE7C,iEAA+C;AAC/C,8DAA4C;AAC5C,+DAA6C;AAC7C,qEAAmD;AACnD,gEAA8C;AAC9C,iEAA+C;AAC/C,iEAA+C;AAC/C,wEAAsD;AACtD,wEAAsD;AAEtD,wEAAsD;AACtD,4EAA0D;AAC1D,8EAA4D;AAC5D,2EAAyD;AACzD,kDAAgC;AAEhC,2EAAyD;AACzD,6EAA2D;AAC3D,0EAAwD;AACxD,2EAAyD;AACzD,2EAAyD;AACzD,wEAAsD;AAEtD,yEAAuD;AACvD,2EAAyD;AACzD,wEAAsD;AACtD,yEAAuD;AACvD,yEAAuD;AAEvD,+EAA6D;AAC7D,iFAA+D;AAC/D,8EAA4D;AAC5D,+EAA6D;AAC7D,+EAA6D;AAE7D,0DAAwC;AAExC,kDAAgC;AAChC,sDAAoC;AACpC,mDAAiC;AACjC,mDAAiC;AACjC,iDAA+B;AAC/B,2DAAyC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.interface.js","sourceRoot":"","sources":["../../../src/common/interface/image.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.HealthCheckDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const shop_slug_enum_1 = require("../../../common/enum/shop-slug.enum");
|
|
15
|
+
class HealthCheckDto {
|
|
16
|
+
}
|
|
17
|
+
exports.HealthCheckDto = HealthCheckDto;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, class_validator_1.IsEnum)(shop_slug_enum_1.ShopSlugEnum),
|
|
20
|
+
__metadata("design:type", String)
|
|
21
|
+
], HealthCheckDto.prototype, "slug", void 0);
|
|
22
|
+
//# sourceMappingURL=health.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.dto.js","sourceRoot":"","sources":["../../../../src/modules/health/dto/health.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAyC;AACzC,wEAAmE;AAEnE,MAAa,cAAc;CAG1B;AAHD,wCAGC;AADC;IADC,IAAA,wBAAM,EAAC,6BAAY,CAAC;;4CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HealthStatus = void 0;
|
|
4
|
+
var HealthStatus;
|
|
5
|
+
(function (HealthStatus) {
|
|
6
|
+
HealthStatus["UP"] = "up";
|
|
7
|
+
HealthStatus["DOWN"] = "down";
|
|
8
|
+
})(HealthStatus || (exports.HealthStatus = HealthStatus = {}));
|
|
9
|
+
//# sourceMappingURL=health-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health-status.js","sourceRoot":"","sources":["../../../../src/modules/health/enum/health-status.ts"],"names":[],"mappings":";;;AAAA,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,yBAAS,CAAA;IACT,6BAAa,CAAA;AACf,CAAC,EAHW,YAAY,4BAAZ,YAAY,QAGvB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { HealthCheckService } from './health.service';
|
|
2
|
+
import { HealthCheckDto } from './dto/health.dto';
|
|
3
|
+
export declare class HealthCheckController {
|
|
4
|
+
private readonly service;
|
|
5
|
+
constructor(service: HealthCheckService);
|
|
6
|
+
health({ slug }: HealthCheckDto): Promise<{
|
|
7
|
+
status: import("@nestjs/terminus").HealthCheckStatus;
|
|
8
|
+
info?: Partial<import("@nestjs/terminus").HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & import("@nestjs/terminus").HealthIndicatorResult>;
|
|
9
|
+
error?: Partial<import("@nestjs/terminus").HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & import("@nestjs/terminus").HealthIndicatorResult>;
|
|
10
|
+
details: import("@nestjs/terminus").HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & import("@nestjs/terminus").HealthIndicatorResult;
|
|
11
|
+
slug: import("../..").ShopSlugEnum;
|
|
12
|
+
timestamp: string;
|
|
13
|
+
}>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.HealthCheckController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const terminus_1 = require("@nestjs/terminus");
|
|
18
|
+
const microservices_1 = require("@nestjs/microservices");
|
|
19
|
+
const scraping_message_pattern_enum_1 = require("../../common/enum/scraping-message-pattern.enum");
|
|
20
|
+
const validation_pipe_1 = require("../../common/pipes/validation.pipe");
|
|
21
|
+
const health_service_1 = require("./health.service");
|
|
22
|
+
const health_dto_1 = require("./dto/health.dto");
|
|
23
|
+
let HealthCheckController = class HealthCheckController {
|
|
24
|
+
constructor(service) {
|
|
25
|
+
this.service = service;
|
|
26
|
+
}
|
|
27
|
+
async health({ slug }) {
|
|
28
|
+
return await this.service.health({ slug });
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
exports.HealthCheckController = HealthCheckController;
|
|
32
|
+
__decorate([
|
|
33
|
+
(0, terminus_1.HealthCheck)(),
|
|
34
|
+
(0, microservices_1.MessagePattern)({ cmd: scraping_message_pattern_enum_1.ScraperMessagePatternEnum.HEALTH }),
|
|
35
|
+
(0, common_1.UsePipes)((0, validation_pipe_1.ValidationPipe)(health_dto_1.HealthCheckDto)),
|
|
36
|
+
__param(0, (0, microservices_1.Payload)()),
|
|
37
|
+
__metadata("design:type", Function),
|
|
38
|
+
__metadata("design:paramtypes", [health_dto_1.HealthCheckDto]),
|
|
39
|
+
__metadata("design:returntype", Promise)
|
|
40
|
+
], HealthCheckController.prototype, "health", null);
|
|
41
|
+
exports.HealthCheckController = HealthCheckController = __decorate([
|
|
42
|
+
(0, common_1.Controller)(),
|
|
43
|
+
__metadata("design:paramtypes", [health_service_1.HealthCheckService])
|
|
44
|
+
], HealthCheckController);
|
|
45
|
+
//# sourceMappingURL=health.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.controller.js","sourceRoot":"","sources":["../../../src/modules/health/health.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAsD;AACtD,+CAA+C;AAC/C,yDAAgE;AAEhE,mGAA4F;AAC5F,wEAAoE;AACpE,qDAAsD;AACtD,iDAAkD;AAG3C,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAChC,YAA6B,OAA2B;QAA3B,YAAO,GAAP,OAAO,CAAoB;IAAG,CAAC;IAKtD,AAAN,KAAK,CAAC,MAAM,CAAY,EAAE,IAAI,EAAkB;QAC9C,OAAO,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF,CAAA;AATY,sDAAqB;AAM1B;IAHL,IAAA,sBAAW,GAAE;IACb,IAAA,8BAAc,EAAC,EAAE,GAAG,EAAE,yDAAyB,CAAC,MAAM,EAAE,CAAC;IACzD,IAAA,iBAAQ,EAAC,IAAA,gCAAc,EAAC,2BAAc,CAAC,CAAC;IAC3B,WAAA,IAAA,uBAAO,GAAE,CAAA;;qCAAW,2BAAc;;mDAE/C;gCARU,qBAAqB;IADjC,IAAA,mBAAU,GAAE;qCAE2B,mCAAkB;GAD7C,qBAAqB,CASjC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.HealthCheckModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const terminus_1 = require("@nestjs/terminus");
|
|
12
|
+
const health_service_1 = require("./health.service");
|
|
13
|
+
const health_controller_1 = require("./health.controller");
|
|
14
|
+
let HealthCheckModule = class HealthCheckModule {
|
|
15
|
+
};
|
|
16
|
+
exports.HealthCheckModule = HealthCheckModule;
|
|
17
|
+
exports.HealthCheckModule = HealthCheckModule = __decorate([
|
|
18
|
+
(0, common_1.Module)({
|
|
19
|
+
imports: [terminus_1.TerminusModule],
|
|
20
|
+
controllers: [health_controller_1.HealthCheckController],
|
|
21
|
+
providers: [health_service_1.HealthCheckService],
|
|
22
|
+
})
|
|
23
|
+
], HealthCheckModule);
|
|
24
|
+
//# sourceMappingURL=health.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.module.js","sourceRoot":"","sources":["../../../src/modules/health/health.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAAkD;AAElD,qDAAsD;AACtD,2DAA4D;AAOrD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IAL7B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,yBAAc,CAAC;QACzB,WAAW,EAAE,CAAC,yCAAqB,CAAC;QACpC,SAAS,EAAE,CAAC,mCAAkB,CAAC;KAChC,CAAC;GACW,iBAAiB,CAAG"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { HealthCheckService as NestHealthCheckService } from '@nestjs/terminus';
|
|
2
|
+
import { HealthIndicatorResult } from '@nestjs/terminus';
|
|
3
|
+
import { HealthCheckDto } from './dto/health.dto';
|
|
4
|
+
export declare class HealthCheckService {
|
|
5
|
+
private readonly service;
|
|
6
|
+
constructor(service: NestHealthCheckService);
|
|
7
|
+
health({ slug }: HealthCheckDto): Promise<{
|
|
8
|
+
status: import("@nestjs/terminus").HealthCheckStatus;
|
|
9
|
+
info?: Partial<HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult>;
|
|
10
|
+
error?: Partial<HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult>;
|
|
11
|
+
details: HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult;
|
|
12
|
+
slug: import("../..").ShopSlugEnum;
|
|
13
|
+
timestamp: string;
|
|
14
|
+
}>;
|
|
15
|
+
private memory;
|
|
16
|
+
private cpu;
|
|
17
|
+
private process;
|
|
18
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.HealthCheckService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const microservices_1 = require("@nestjs/microservices");
|
|
18
|
+
const terminus_1 = require("@nestjs/terminus");
|
|
19
|
+
const health_dto_1 = require("./dto/health.dto");
|
|
20
|
+
const health_status_1 = require("./enum/health-status");
|
|
21
|
+
let HealthCheckService = class HealthCheckService {
|
|
22
|
+
constructor(service) {
|
|
23
|
+
this.service = service;
|
|
24
|
+
}
|
|
25
|
+
async health({ slug }) {
|
|
26
|
+
const result = await this.service.check([
|
|
27
|
+
() => this.process(),
|
|
28
|
+
() => this.memory(),
|
|
29
|
+
() => this.cpu(),
|
|
30
|
+
]);
|
|
31
|
+
return { slug, timestamp: new Date().toISOString(), ...result };
|
|
32
|
+
}
|
|
33
|
+
memory() {
|
|
34
|
+
const memory = process.memoryUsage();
|
|
35
|
+
const details = {
|
|
36
|
+
rss: Math.round((memory.rss / 1024 / 1024) * 100) / 100,
|
|
37
|
+
heapUsed: Math.round((memory.heapUsed / 1024 / 1024) * 100) / 100,
|
|
38
|
+
heapTotal: Math.round((memory.heapTotal / 1024 / 1024) * 100) / 100,
|
|
39
|
+
external: Math.round((memory.external / 1024 / 1024) * 100) / 100,
|
|
40
|
+
};
|
|
41
|
+
const status = details.heapUsed < 500 ? health_status_1.HealthStatus.UP : health_status_1.HealthStatus.DOWN;
|
|
42
|
+
return { memory: { status, details } };
|
|
43
|
+
}
|
|
44
|
+
cpu() {
|
|
45
|
+
const usage = process.cpuUsage();
|
|
46
|
+
const uptime = process.uptime();
|
|
47
|
+
const percent = ((usage.user + usage.system) / (uptime * 1000000)) * 100;
|
|
48
|
+
const status = percent < 80 ? health_status_1.HealthStatus.UP : health_status_1.HealthStatus.DOWN;
|
|
49
|
+
const details = {
|
|
50
|
+
user: usage.user,
|
|
51
|
+
system: usage.system,
|
|
52
|
+
percent: Math.round(percent * 100) / 100,
|
|
53
|
+
};
|
|
54
|
+
return { cpu: { status, details } };
|
|
55
|
+
}
|
|
56
|
+
process() {
|
|
57
|
+
return {
|
|
58
|
+
process: {
|
|
59
|
+
status: health_status_1.HealthStatus.UP,
|
|
60
|
+
details: {
|
|
61
|
+
pid: process.pid,
|
|
62
|
+
uptime: Math.round(process.uptime() * 100) / 100,
|
|
63
|
+
platform: process.platform,
|
|
64
|
+
nodeVersion: process.version,
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
exports.HealthCheckService = HealthCheckService;
|
|
71
|
+
__decorate([
|
|
72
|
+
__param(0, (0, microservices_1.Payload)()),
|
|
73
|
+
__metadata("design:type", Function),
|
|
74
|
+
__metadata("design:paramtypes", [health_dto_1.HealthCheckDto]),
|
|
75
|
+
__metadata("design:returntype", Promise)
|
|
76
|
+
], HealthCheckService.prototype, "health", null);
|
|
77
|
+
exports.HealthCheckService = HealthCheckService = __decorate([
|
|
78
|
+
(0, common_1.Injectable)(),
|
|
79
|
+
__metadata("design:paramtypes", [terminus_1.HealthCheckService])
|
|
80
|
+
], HealthCheckService);
|
|
81
|
+
//# sourceMappingURL=health.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.service.js","sourceRoot":"","sources":["../../../src/modules/health/health.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,yDAAgD;AAChD,+CAAgF;AAGhF,iDAAkD;AAClD,wDAAoD;AAG7C,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC7B,YAA6B,OAA+B;QAA/B,YAAO,GAAP,OAAO,CAAwB;IAAG,CAAC;IAE1D,AAAN,KAAK,CAAC,MAAM,CAAY,EAAE,IAAI,EAAkB;QAC9C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;YACtC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE;YACpB,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;YACnB,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;SACjB,CAAC,CAAC;QACH,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC;IAClE,CAAC;IAEO,MAAM;QACZ,MAAM,MAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG;YACd,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG;YACvD,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG;YACjE,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG;YACnE,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG;SAClE,CAAC;QAEF,MAAM,MAAM,GAAG,OAAO,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,4BAAY,CAAC,EAAE,CAAC,CAAC,CAAC,4BAAY,CAAC,IAAI,CAAC;QAE5E,OAAO,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC;IACzC,CAAC;IAEO,GAAG;QACT,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAEhC,MAAM,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,GAAG,CAAC;QAEzE,MAAM,MAAM,GAAG,OAAO,GAAG,EAAE,CAAC,CAAC,CAAC,4BAAY,CAAC,EAAE,CAAC,CAAC,CAAC,4BAAY,CAAC,IAAI,CAAC;QAClE,MAAM,OAAO,GAAG;YACd,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,GAAG;SACzC,CAAC;QAEF,OAAO,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC;IACtC,CAAC;IAEO,OAAO;QACb,OAAO;YACL,OAAO,EAAE;gBACP,MAAM,EAAE,4BAAY,CAAC,EAAE;gBACvB,OAAO,EAAE;oBACP,GAAG,EAAE,OAAO,CAAC,GAAG;oBAChB,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,GAAG,GAAG;oBAChD,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,WAAW,EAAE,OAAO,CAAC,OAAO;iBAC7B;aACF;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AAvDY,gDAAkB;AAGvB;IAAQ,WAAA,IAAA,uBAAO,GAAE,CAAA;;qCAAW,2BAAc;;gDAO/C;6BAVU,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;qCAE2B,6BAAsB;GADjD,kBAAkB,CAuD9B"}
|
package/dist/modules/index.d.ts
CHANGED
|
@@ -13,6 +13,7 @@ export * from './delayer/delayer.service';
|
|
|
13
13
|
export * from './delayer/use-cases/delayer-config.service';
|
|
14
14
|
export * from './delayer/use-cases/delayer-mapper.service';
|
|
15
15
|
export * from './delayer/use-cases/delayer-sleeper.service';
|
|
16
|
+
export * from './health/health.module';
|
|
16
17
|
export * from './minio/minio.module';
|
|
17
18
|
export * from './minio/minio.service';
|
|
18
19
|
export * from './minio/env/minio.env.config';
|
package/dist/modules/index.js
CHANGED
|
@@ -29,6 +29,7 @@ __exportStar(require("./delayer/delayer.service"), exports);
|
|
|
29
29
|
__exportStar(require("./delayer/use-cases/delayer-config.service"), exports);
|
|
30
30
|
__exportStar(require("./delayer/use-cases/delayer-mapper.service"), exports);
|
|
31
31
|
__exportStar(require("./delayer/use-cases/delayer-sleeper.service"), exports);
|
|
32
|
+
__exportStar(require("./health/health.module"), exports);
|
|
32
33
|
__exportStar(require("./minio/minio.module"), exports);
|
|
33
34
|
__exportStar(require("./minio/minio.service"), exports);
|
|
34
35
|
__exportStar(require("./minio/env/minio.env.config"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/modules/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,4DAA0C;AAC1C,8EAA4D;AAC5D,sFAAoE;AACpE,oFAAkE;AAClE,8EAA4D;AAE5D,iEAA+C;AAC/C,kEAAgD;AAEhD,iEAA+C;AAC/C,qEAAmD;AACnD,2DAAyC;AACzC,4DAA0C;AAC1C,6EAA2D;AAC3D,6EAA2D;AAC3D,8EAA4D;AAE5D,uDAAqC;AACrC,wDAAsC;AACtC,+DAA6C;AAC7C,mEAAiD;AAEjD,+DAA6C;AAC7C,gEAA8C;AAE9C,+DAA6C;AAC7C,gEAA8C;AAE9C,qEAAmD;AACnD,yEAAuD;AACvD,6DAA2C;AAC3C,8DAA4C;AAE5C,iEAA+C;AAC/C,kEAAgD;AAEhD,2DAAyC;AACzC,4DAA0C;AAE1C,qEAAmD;AACnD,yEAAuD;AACvD,6DAA2C;AAC3C,8DAA4C;AAE5C,6DAA2C;AAC3C,8DAA4C;AAE5C,uEAAqD;AACrD,2EAAyD;AACzD,+DAA6C;AAC7C,gEAA8C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/modules/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,4DAA0C;AAC1C,8EAA4D;AAC5D,sFAAoE;AACpE,oFAAkE;AAClE,8EAA4D;AAE5D,iEAA+C;AAC/C,kEAAgD;AAEhD,iEAA+C;AAC/C,qEAAmD;AACnD,2DAAyC;AACzC,4DAA0C;AAC1C,6EAA2D;AAC3D,6EAA2D;AAC3D,8EAA4D;AAE5D,yDAAuC;AAEvC,uDAAqC;AACrC,wDAAsC;AACtC,+DAA6C;AAC7C,mEAAiD;AAEjD,+DAA6C;AAC7C,gEAA8C;AAE9C,+DAA6C;AAC7C,gEAA8C;AAE9C,qEAAmD;AACnD,yEAAuD;AACvD,6DAA2C;AAC3C,8DAA4C;AAE5C,iEAA+C;AAC/C,kEAAgD;AAEhD,2DAAyC;AACzC,4DAA0C;AAE1C,qEAAmD;AACnD,yEAAuD;AACvD,6DAA2C;AAC3C,8DAA4C;AAE5C,6DAA2C;AAC3C,8DAA4C;AAE5C,uEAAqD;AACrD,2EAAyD;AACzD,+DAA6C;AAC7C,gEAA8C"}
|
|
@@ -13,6 +13,7 @@ const category_repository_service_1 = require("./services/category.repository.se
|
|
|
13
13
|
const product_repository_service_1 = require("./services/product.repository.service");
|
|
14
14
|
const provider_repository_service_1 = require("./services/provider.repository.service");
|
|
15
15
|
const province_repository_service_1 = require("./services/province.repository.service");
|
|
16
|
+
const image_repository_service_1 = require("./services/image.repository.service");
|
|
16
17
|
let RepositoryModule = class RepositoryModule {
|
|
17
18
|
};
|
|
18
19
|
exports.RepositoryModule = RepositoryModule;
|
|
@@ -21,6 +22,7 @@ exports.RepositoryModule = RepositoryModule = __decorate([
|
|
|
21
22
|
providers: [
|
|
22
23
|
repository_service_1.RepositoryService,
|
|
23
24
|
category_repository_service_1.CategoryRepositoryService,
|
|
25
|
+
image_repository_service_1.ImageRepositoryService,
|
|
24
26
|
product_repository_service_1.ProductRepositoryService,
|
|
25
27
|
provider_repository_service_1.ProviderRepositoryService,
|
|
26
28
|
province_repository_service_1.ProvinceRepositoryService,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"repository.module.js","sourceRoot":"","sources":["../../../src/modules/repository/repository.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AAExC,6DAAyD;AACzD,wFAAmF;AACnF,sFAAiF;AACjF,wFAAmF;AACnF,wFAAmF;
|
|
1
|
+
{"version":3,"file":"repository.module.js","sourceRoot":"","sources":["../../../src/modules/repository/repository.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AAExC,6DAAyD;AACzD,wFAAmF;AACnF,sFAAiF;AACjF,wFAAmF;AACnF,wFAAmF;AACnF,kFAA6E;AAatE,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;CAAG,CAAA;AAAnB,4CAAgB;2BAAhB,gBAAgB;IAX5B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE;YACT,sCAAiB;YACjB,uDAAyB;YACzB,iDAAsB;YACtB,qDAAwB;YACxB,uDAAyB;YACzB,uDAAyB;SAC1B;QACD,OAAO,EAAE,CAAC,sCAAiB,CAAC;KAC7B,CAAC;GACW,gBAAgB,CAAG"}
|
|
@@ -1,23 +1,28 @@
|
|
|
1
1
|
import { ProvinceRepositoryService } from './services/province.repository.service';
|
|
2
2
|
import { CategoryRepositoryService } from './services/category.repository.service';
|
|
3
|
+
import { ImageRepositoryService } from './services/image.repository.service';
|
|
3
4
|
import { ProviderRepositoryService } from './services/provider.repository.service';
|
|
4
5
|
import { ProductRepositoryService } from './services/product.repository.service';
|
|
5
6
|
import { Province } from '../../common/class/province';
|
|
6
7
|
import { Category } from '../../common/class/category';
|
|
8
|
+
import { Image } from '../../common/class/image';
|
|
7
9
|
import { Provider } from '../../common/class/provider';
|
|
8
10
|
import { Product } from '../../common/class/product';
|
|
9
11
|
export declare class RepositoryService {
|
|
10
|
-
private readonly
|
|
11
|
-
private readonly
|
|
12
|
-
private readonly
|
|
13
|
-
private readonly
|
|
12
|
+
private readonly _province;
|
|
13
|
+
private readonly _image;
|
|
14
|
+
private readonly _category;
|
|
15
|
+
private readonly _provider;
|
|
16
|
+
private readonly _product;
|
|
14
17
|
private logger;
|
|
15
|
-
constructor(
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
constructor(_province: ProvinceRepositoryService, _image: ImageRepositoryService, _category: CategoryRepositoryService, _provider: ProviderRepositoryService, _product: ProductRepositoryService);
|
|
19
|
+
get categories(): Category[];
|
|
20
|
+
get images(): Image[];
|
|
21
|
+
get products(): Product[];
|
|
22
|
+
get providers(): Provider[];
|
|
23
|
+
get provinces(): Province[];
|
|
20
24
|
saveCategories(categories: Category[]): void;
|
|
25
|
+
saveImages(images: Image[]): void;
|
|
21
26
|
saveProducts(products: Product[]): void;
|
|
22
27
|
saveProviders(providers: Provider[]): void;
|
|
23
28
|
saveProvinces(provinces: Province[]): void;
|
|
@@ -15,48 +15,57 @@ const common_1 = require("@nestjs/common");
|
|
|
15
15
|
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
16
16
|
const province_repository_service_1 = require("./services/province.repository.service");
|
|
17
17
|
const category_repository_service_1 = require("./services/category.repository.service");
|
|
18
|
+
const image_repository_service_1 = require("./services/image.repository.service");
|
|
18
19
|
const provider_repository_service_1 = require("./services/provider.repository.service");
|
|
19
20
|
const product_repository_service_1 = require("./services/product.repository.service");
|
|
20
21
|
const logger_1 = require("../../common/logger/logger");
|
|
21
22
|
const event_enum_1 = require("../../common/enum/event.enum");
|
|
22
23
|
let RepositoryService = RepositoryService_1 = class RepositoryService {
|
|
23
|
-
constructor(
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this.
|
|
24
|
+
constructor(_province, _image, _category, _provider, _product) {
|
|
25
|
+
this._province = _province;
|
|
26
|
+
this._image = _image;
|
|
27
|
+
this._category = _category;
|
|
28
|
+
this._provider = _provider;
|
|
29
|
+
this._product = _product;
|
|
28
30
|
this.logger = new logger_1.Logger(RepositoryService_1.name);
|
|
29
31
|
}
|
|
30
|
-
|
|
31
|
-
return this.
|
|
32
|
+
get categories() {
|
|
33
|
+
return this._category.categories;
|
|
32
34
|
}
|
|
33
|
-
|
|
34
|
-
return this.
|
|
35
|
+
get images() {
|
|
36
|
+
return this._image.images;
|
|
35
37
|
}
|
|
36
|
-
|
|
37
|
-
return this.
|
|
38
|
+
get products() {
|
|
39
|
+
return this._product.products;
|
|
38
40
|
}
|
|
39
|
-
|
|
40
|
-
return this.
|
|
41
|
+
get providers() {
|
|
42
|
+
return this._provider.providers;
|
|
43
|
+
}
|
|
44
|
+
get provinces() {
|
|
45
|
+
return this._province.provinces;
|
|
41
46
|
}
|
|
42
47
|
saveCategories(categories) {
|
|
43
|
-
this.
|
|
48
|
+
this._category.save(categories);
|
|
49
|
+
}
|
|
50
|
+
saveImages(images) {
|
|
51
|
+
this._image.save(images);
|
|
44
52
|
}
|
|
45
53
|
saveProducts(products) {
|
|
46
|
-
this.
|
|
54
|
+
this._product.save(products);
|
|
47
55
|
}
|
|
48
56
|
saveProviders(providers) {
|
|
49
|
-
this.
|
|
57
|
+
this._provider.save(providers);
|
|
50
58
|
}
|
|
51
59
|
saveProvinces(provinces) {
|
|
52
|
-
this.
|
|
60
|
+
this._province.save(provinces);
|
|
53
61
|
}
|
|
54
62
|
reset() {
|
|
55
63
|
const services = [
|
|
56
|
-
this.
|
|
57
|
-
this.
|
|
58
|
-
this.
|
|
59
|
-
this.
|
|
64
|
+
this._province,
|
|
65
|
+
this._category,
|
|
66
|
+
this._image,
|
|
67
|
+
this._provider,
|
|
68
|
+
this._product,
|
|
60
69
|
];
|
|
61
70
|
services.forEach((x) => x.reset());
|
|
62
71
|
this.logger.log('✅ Repository reset successfully');
|
|
@@ -69,6 +78,12 @@ __decorate([
|
|
|
69
78
|
__metadata("design:paramtypes", [Array]),
|
|
70
79
|
__metadata("design:returntype", void 0)
|
|
71
80
|
], RepositoryService.prototype, "saveCategories", null);
|
|
81
|
+
__decorate([
|
|
82
|
+
(0, event_emitter_1.OnEvent)(event_enum_1.ScrapingEvent.SAVE_IMAGES),
|
|
83
|
+
__metadata("design:type", Function),
|
|
84
|
+
__metadata("design:paramtypes", [Array]),
|
|
85
|
+
__metadata("design:returntype", void 0)
|
|
86
|
+
], RepositoryService.prototype, "saveImages", null);
|
|
72
87
|
__decorate([
|
|
73
88
|
(0, event_emitter_1.OnEvent)(event_enum_1.ScrapingEvent.SAVE_PRODUCTS),
|
|
74
89
|
__metadata("design:type", Function),
|
|
@@ -96,6 +111,7 @@ __decorate([
|
|
|
96
111
|
exports.RepositoryService = RepositoryService = RepositoryService_1 = __decorate([
|
|
97
112
|
(0, common_1.Injectable)(),
|
|
98
113
|
__metadata("design:paramtypes", [province_repository_service_1.ProvinceRepositoryService,
|
|
114
|
+
image_repository_service_1.ImageRepositoryService,
|
|
99
115
|
category_repository_service_1.CategoryRepositoryService,
|
|
100
116
|
provider_repository_service_1.ProviderRepositoryService,
|
|
101
117
|
product_repository_service_1.ProductRepositoryService])
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"repository.service.js","sourceRoot":"","sources":["../../../src/modules/repository/repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,yDAAgD;AAEhD,wFAAmF;AACnF,wFAAmF;AACnF,wFAAmF;AACnF,sFAAiF;AAEjF,uDAAoD;AACpD,6DAA6D;
|
|
1
|
+
{"version":3,"file":"repository.service.js","sourceRoot":"","sources":["../../../src/modules/repository/repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,yDAAgD;AAEhD,wFAAmF;AACnF,wFAAmF;AACnF,kFAA6E;AAC7E,wFAAmF;AACnF,sFAAiF;AAEjF,uDAAoD;AACpD,6DAA6D;AAQtD,IAAM,iBAAiB,yBAAvB,MAAM,iBAAiB;IAG5B,YACmB,SAAoC,EACpC,MAA8B,EAC9B,SAAoC,EACpC,SAAoC,EACpC,QAAkC;QAJlC,cAAS,GAAT,SAAS,CAA2B;QACpC,WAAM,GAAN,MAAM,CAAwB;QAC9B,cAAS,GAAT,SAAS,CAA2B;QACpC,cAAS,GAAT,SAAS,CAA2B;QACpC,aAAQ,GAAR,QAAQ,CAA0B;QAP7C,WAAM,GAAG,IAAI,eAAM,CAAC,mBAAiB,CAAC,IAAI,CAAC,CAAC;IAQjD,CAAC;IAEJ,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;IACnC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAChC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;IAClC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;IAClC,CAAC;IAGD,cAAc,CAAC,UAAsB;QACnC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAGD,UAAU,CAAC,MAAe;QACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAGD,YAAY,CAAC,QAAmB;QAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAGD,aAAa,CAAC,SAAqB;QACjC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjC,CAAC;IAGD,aAAa,CAAC,SAAqB;QACjC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjC,CAAC;IAGD,KAAK;QACH,MAAM,QAAQ,GAAG;YACf,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,MAAM;YACX,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,QAAQ;SACd,CAAC;QACF,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC;IACrD,CAAC;CACF,CAAA;AApEY,8CAAiB;AAgC5B;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,eAAe,CAAC;;;;uDAGtC;AAGD;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,WAAW,CAAC;;;;mDAGlC;AAGD;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,aAAa,CAAC;;;;qDAGpC;AAGD;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,cAAc,CAAC;;;;sDAGrC;AAGD;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,cAAc,CAAC;;;;sDAGrC;AAGD;IADC,IAAA,uBAAO,EAAC,0BAAa,CAAC,KAAK,CAAC;;;;8CAW5B;4BAnEU,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAKmB,uDAAyB;QAC5B,iDAAsB;QACnB,uDAAyB;QACzB,uDAAyB;QAC1B,qDAAwB;GAR1C,iBAAiB,CAoE7B"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Category } from '../../../common/class/category';
|
|
2
2
|
export declare class CategoryRepositoryService {
|
|
3
3
|
private logger;
|
|
4
|
-
private
|
|
4
|
+
private _categories;
|
|
5
5
|
constructor();
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
get categories(): Category[];
|
|
7
|
+
save(categories: Category[]): void;
|
|
8
8
|
reset(): void;
|
|
9
9
|
}
|
|
@@ -16,25 +16,25 @@ const logger_1 = require("../../../common/logger/logger");
|
|
|
16
16
|
let CategoryRepositoryService = class CategoryRepositoryService {
|
|
17
17
|
constructor() {
|
|
18
18
|
this.logger = new logger_1.Logger(repository_service_1.RepositoryService.name);
|
|
19
|
-
this.
|
|
19
|
+
this._categories = new Map();
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
const values = this.
|
|
21
|
+
get categories() {
|
|
22
|
+
const values = this._categories.values();
|
|
23
23
|
return Array.from(values);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
save(categories) {
|
|
26
26
|
categories.forEach((category) => {
|
|
27
27
|
const { id, name } = category.getData();
|
|
28
|
-
if (!this.
|
|
29
|
-
this.
|
|
28
|
+
if (!this._categories.has(id)) {
|
|
29
|
+
this._categories.set(id, category);
|
|
30
30
|
this.logger.debug(name);
|
|
31
31
|
}
|
|
32
32
|
});
|
|
33
|
-
const { size } = this.
|
|
33
|
+
const { size } = this._categories;
|
|
34
34
|
this.logger.verbose(`✅ ${size} Categories saved successfully`);
|
|
35
35
|
}
|
|
36
36
|
reset() {
|
|
37
|
-
this.
|
|
37
|
+
this._categories.clear();
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
40
|
exports.CategoryRepositoryService = CategoryRepositoryService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"category.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/category.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAIpC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,
|
|
1
|
+
{"version":3,"file":"category.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/category.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAIpC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,gBAAW,GAA0B,IAAI,GAAG,EAAE,CAAC;IAExC,CAAC;IAEhB,IAAI,UAAU;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QACzC,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC,UAAsB;QACzB,UAAU,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC9B,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC;YACxC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC;QAClC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,gCAAgC,CAAC,CAAC;IACjE,CAAC;IAED,KAAK;QACH,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;CACF,CAAA;AA1BY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,mBAAU,GAAE;;GACA,yBAAyB,CA0BrC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ImageRepositoryService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const repository_service_1 = require("../repository.service");
|
|
15
|
+
const logger_1 = require("../../../common/logger/logger");
|
|
16
|
+
let ImageRepositoryService = class ImageRepositoryService {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.logger = new logger_1.Logger(repository_service_1.RepositoryService.name);
|
|
19
|
+
this._images = new Map();
|
|
20
|
+
}
|
|
21
|
+
get images() {
|
|
22
|
+
const values = this._images.values();
|
|
23
|
+
return Array.from(values);
|
|
24
|
+
}
|
|
25
|
+
save(images) {
|
|
26
|
+
images.forEach((image) => {
|
|
27
|
+
const { id, name } = image.getData();
|
|
28
|
+
if (!this._images.has(id)) {
|
|
29
|
+
this._images.set(id, image);
|
|
30
|
+
this.logger.debug(name);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
const { size } = this._images;
|
|
34
|
+
this.logger.verbose(`✅ ${size} Images saved successfully`);
|
|
35
|
+
}
|
|
36
|
+
reset() {
|
|
37
|
+
this._images.clear();
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
exports.ImageRepositoryService = ImageRepositoryService;
|
|
41
|
+
exports.ImageRepositoryService = ImageRepositoryService = __decorate([
|
|
42
|
+
(0, common_1.Injectable)(),
|
|
43
|
+
__metadata("design:paramtypes", [])
|
|
44
|
+
], ImageRepositoryService);
|
|
45
|
+
//# sourceMappingURL=image.repository.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/image.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAIjC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,YAAO,GAAuB,IAAI,GAAG,EAAE,CAAC;IAEjC,CAAC;IAEhB,IAAI,MAAM;QACR,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACrC,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC,MAAe;QAClB,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACvB,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC;YACrC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;gBAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,4BAA4B,CAAC,CAAC;IAC7D,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;CACF,CAAA;AA1BY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;;GACA,sBAAsB,CA0BlC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Product } from '../../../common/class/product';
|
|
2
2
|
export declare class ProductRepositoryService {
|
|
3
3
|
private logger;
|
|
4
|
-
private
|
|
4
|
+
private _products;
|
|
5
5
|
constructor();
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
get products(): Product[];
|
|
7
|
+
save(products: Product[]): void;
|
|
8
8
|
reset(): void;
|
|
9
9
|
}
|
|
@@ -16,24 +16,24 @@ const logger_1 = require("../../../common/logger/logger");
|
|
|
16
16
|
let ProductRepositoryService = class ProductRepositoryService {
|
|
17
17
|
constructor() {
|
|
18
18
|
this.logger = new logger_1.Logger(repository_service_1.RepositoryService.name);
|
|
19
|
-
this.
|
|
19
|
+
this._products = new Map();
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
const values = this.
|
|
21
|
+
get products() {
|
|
22
|
+
const values = this._products.values();
|
|
23
23
|
return Array.from(values);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
save(products) {
|
|
26
26
|
const sizes = { previous: 0, current: 0 };
|
|
27
27
|
const multiples = { previous: 0, current: 0 };
|
|
28
|
-
sizes.previous = this.
|
|
28
|
+
sizes.previous = this._products.size;
|
|
29
29
|
products.forEach((product) => {
|
|
30
30
|
const { id, url } = product.getData();
|
|
31
|
-
if (id && !this.
|
|
32
|
-
this.
|
|
31
|
+
if (id && !this._products.has(id)) {
|
|
32
|
+
this._products.set(id, product);
|
|
33
33
|
this.logger.debug(`✅ ${url}`);
|
|
34
34
|
}
|
|
35
35
|
});
|
|
36
|
-
sizes.current = this.
|
|
36
|
+
sizes.current = this._products.size;
|
|
37
37
|
multiples.previous = Math.floor(sizes.previous / 10);
|
|
38
38
|
multiples.current = Math.floor(sizes.current / 10);
|
|
39
39
|
if (multiples.current > multiples.previous) {
|
|
@@ -42,7 +42,7 @@ let ProductRepositoryService = class ProductRepositoryService {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
reset() {
|
|
45
|
-
this.
|
|
45
|
+
this._products.clear();
|
|
46
46
|
}
|
|
47
47
|
};
|
|
48
48
|
exports.ProductRepositoryService = ProductRepositoryService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"product.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/product.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAInC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,
|
|
1
|
+
{"version":3,"file":"product.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/product.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAInC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,cAAS,GAAyB,IAAI,GAAG,EAAE,CAAC;IAErC,CAAC;IAEhB,IAAI,QAAQ;QACV,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;QACvC,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC,QAAmB;QACtB,MAAM,KAAK,GAAG,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;QAC1C,MAAM,SAAS,GAAG,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;QAC9C,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QAErC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3B,MAAM,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YACtC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBAChC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;YAChC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QACpC,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;QACrD,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC;QAEnD,IAAI,SAAS,CAAC,OAAO,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC3C,MAAM,OAAO,GAAG,KAAK,KAAK,CAAC,OAAO,uCAAuC,CAAC;YAC1E,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;CACF,CAAA;AArCY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,mBAAU,GAAE;;GACA,wBAAwB,CAqCpC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Provider } from '../../../common/class/provider';
|
|
2
2
|
export declare class ProviderRepositoryService {
|
|
3
3
|
private logger;
|
|
4
|
-
private
|
|
4
|
+
private _providers;
|
|
5
5
|
constructor();
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
get providers(): Provider[];
|
|
7
|
+
save(providers: Provider[]): void;
|
|
8
8
|
reset(): void;
|
|
9
9
|
}
|
|
@@ -16,25 +16,25 @@ const logger_1 = require("../../../common/logger/logger");
|
|
|
16
16
|
let ProviderRepositoryService = class ProviderRepositoryService {
|
|
17
17
|
constructor() {
|
|
18
18
|
this.logger = new logger_1.Logger(repository_service_1.RepositoryService.name);
|
|
19
|
-
this.
|
|
19
|
+
this._providers = new Map();
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
const values = this.
|
|
21
|
+
get providers() {
|
|
22
|
+
const values = this._providers.values();
|
|
23
23
|
return Array.from(values);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
save(providers) {
|
|
26
26
|
providers.forEach((provider) => {
|
|
27
27
|
const { id, name } = provider.getData();
|
|
28
|
-
if (!this.
|
|
29
|
-
this.
|
|
28
|
+
if (!this._providers.has(id)) {
|
|
29
|
+
this._providers.set(id, provider);
|
|
30
30
|
this.logger.debug(name);
|
|
31
31
|
}
|
|
32
32
|
});
|
|
33
|
-
const { size } = this.
|
|
33
|
+
const { size } = this._providers;
|
|
34
34
|
this.logger.verbose(`✅ ${size} Providers saved successfully`);
|
|
35
35
|
}
|
|
36
36
|
reset() {
|
|
37
|
-
this.
|
|
37
|
+
this._providers.clear();
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
40
|
exports.ProviderRepositoryService = ProviderRepositoryService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/provider.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAIpC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,
|
|
1
|
+
{"version":3,"file":"provider.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/provider.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8DAA0D;AAC1D,0DAAuD;AAIhD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAIpC;QAHQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,eAAU,GAA0B,IAAI,GAAG,EAAE,CAAC;IAEvC,CAAC;IAEhB,IAAI,SAAS;QACX,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACxC,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC,SAAqB;QACxB,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC7B,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC;YACxC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;gBAClC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,+BAA+B,CAAC,CAAC;IAChE,CAAC;IAED,KAAK;QACH,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC;CACF,CAAA;AA1BY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,mBAAU,GAAE;;GACA,yBAAyB,CA0BrC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Province } from '../../../common/class/province';
|
|
2
2
|
export declare class ProvinceRepositoryService {
|
|
3
3
|
private logger;
|
|
4
|
-
private
|
|
4
|
+
private _provinces;
|
|
5
5
|
constructor();
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
get provinces(): Province[];
|
|
7
|
+
save(provinces: Province[]): void;
|
|
8
8
|
reset(): void;
|
|
9
9
|
}
|
|
@@ -16,25 +16,25 @@ const repository_service_1 = require("./../repository.service");
|
|
|
16
16
|
let ProvinceRepositoryService = class ProvinceRepositoryService {
|
|
17
17
|
constructor() {
|
|
18
18
|
this.logger = new logger_1.Logger(repository_service_1.RepositoryService.name);
|
|
19
|
-
this.
|
|
19
|
+
this._provinces = new Map();
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
const values = this.
|
|
21
|
+
get provinces() {
|
|
22
|
+
const values = this._provinces.values();
|
|
23
23
|
return Array.from(values);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
save(provinces) {
|
|
26
26
|
provinces.forEach((province) => {
|
|
27
27
|
const { id, name } = province.getData();
|
|
28
|
-
if (!this.
|
|
29
|
-
this.
|
|
28
|
+
if (!this._provinces.has(id)) {
|
|
29
|
+
this._provinces.set(id, province);
|
|
30
30
|
this.logger.debug(name);
|
|
31
31
|
}
|
|
32
32
|
});
|
|
33
|
-
const { size } = this.
|
|
33
|
+
const { size } = this._provinces;
|
|
34
34
|
this.logger.verbose(`✅ ${size} Provinces saved successfully`);
|
|
35
35
|
}
|
|
36
36
|
reset() {
|
|
37
|
-
this.
|
|
37
|
+
this._provinces.clear();
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
40
|
exports.ProvinceRepositoryService = ProvinceRepositoryService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"province.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/province.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,0DAAuD;AACvD,gEAA4D;AAIrD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAKpC;QAJQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAE5C,
|
|
1
|
+
{"version":3,"file":"province.repository.service.js","sourceRoot":"","sources":["../../../../src/modules/repository/services/province.repository.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,0DAAuD;AACvD,gEAA4D;AAIrD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAKpC;QAJQ,WAAM,GAAG,IAAI,eAAM,CAAC,sCAAiB,CAAC,IAAI,CAAC,CAAC;QAE5C,eAAU,GAA0B,IAAI,GAAG,EAAE,CAAC;IAEvC,CAAC;IAEhB,IAAI,SAAS;QACX,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACxC,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,CAAC,SAAqB;QACxB,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC7B,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC;YACxC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;gBAClC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,+BAA+B,CAAC,CAAC;IAChE,CAAC;IAED,KAAK;QACH,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC;CACF,CAAA;AA3BY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,mBAAU,GAAE;;GACA,yBAAyB,CA2BrC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rafikidota/cuba-ofertas-scraping",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.32.0",
|
|
4
4
|
"description": "Sometimes, the best way to solve your own problems is to help someone else.",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -15,26 +15,29 @@
|
|
|
15
15
|
"module": "./dist/index.js",
|
|
16
16
|
"types": "./dist/index.d.ts",
|
|
17
17
|
"devDependencies": {
|
|
18
|
-
"@aws-sdk/client-s3": "3.
|
|
19
|
-
"@aws-sdk/s3-request-presigner": "3.
|
|
18
|
+
"@aws-sdk/client-s3": "3.1012.0",
|
|
19
|
+
"@aws-sdk/s3-request-presigner": "3.1012.0",
|
|
20
20
|
"@crawlee/cheerio": "3.16.0",
|
|
21
21
|
"@crawlee/playwright": "3.16.0",
|
|
22
22
|
"@eslint/eslintrc": "3.3.5",
|
|
23
23
|
"@eslint/js": "10.0.1",
|
|
24
24
|
"@nestjs/axios": "4.0.1",
|
|
25
|
-
"@nestjs/common": "11.1.
|
|
25
|
+
"@nestjs/common": "11.1.17",
|
|
26
26
|
"@nestjs/config": "4.0.3",
|
|
27
|
-
"@nestjs/core": "11.1.
|
|
27
|
+
"@nestjs/core": "11.1.17",
|
|
28
28
|
"@nestjs/event-emitter": "3.0.1",
|
|
29
|
-
"@nestjs/microservices": "11.1.
|
|
29
|
+
"@nestjs/microservices": "11.1.17",
|
|
30
30
|
"@nestjs/schedule": "6.1.1",
|
|
31
|
+
"@nestjs/terminus": "11.1.1",
|
|
31
32
|
"@types/archiver": "7.0.0",
|
|
32
|
-
"@types/node": "25.
|
|
33
|
-
"@typescript-eslint/eslint-plugin": "8.
|
|
34
|
-
"@typescript-eslint/parser": "8.
|
|
33
|
+
"@types/node": "25.5.0",
|
|
34
|
+
"@typescript-eslint/eslint-plugin": "8.57.1",
|
|
35
|
+
"@typescript-eslint/parser": "8.57.1",
|
|
35
36
|
"archiver": "7.0.1",
|
|
36
37
|
"axios": "1.13.6",
|
|
37
38
|
"cheerio": "1.2.0",
|
|
39
|
+
"class-transformer": "0.5.1",
|
|
40
|
+
"class-validator": "0.15.1",
|
|
38
41
|
"crawlee": "3.16.0",
|
|
39
42
|
"dotenv": "17.3.1",
|
|
40
43
|
"eslint": "10.0.3",
|
|
@@ -45,14 +48,14 @@
|
|
|
45
48
|
"https-proxy-agent": "7.0.6",
|
|
46
49
|
"husky": "9.1.7",
|
|
47
50
|
"joi": "18.0.2",
|
|
48
|
-
"lint-staged": "16.
|
|
51
|
+
"lint-staged": "16.4.0",
|
|
49
52
|
"playwright": "1.58.2",
|
|
50
53
|
"prettier": "3.8.1",
|
|
51
54
|
"rimraf": "6.1.3",
|
|
52
55
|
"rxjs": "7.8.2",
|
|
53
56
|
"telegraf": "4.16.3",
|
|
54
57
|
"typescript": "5.9.3",
|
|
55
|
-
"typescript-eslint": "8.
|
|
58
|
+
"typescript-eslint": "8.57.1"
|
|
56
59
|
},
|
|
57
60
|
"scripts": {
|
|
58
61
|
"prebuild": "rimraf -rf dist",
|