UNPKG

@joktec/mysql

Version:

JokTec - MySql Service

185 lines 6.74 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); 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; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.MysqlConfig = exports.MysqlBenchmarkConfig = exports.MysqlLogLevel = exports.Dialect = exports.MysqlSlaveConfig = void 0; const core_1 = require("@joktec/core"); const utils_1 = require("@joktec/utils"); const lodash_1 = require("lodash"); class MysqlSlaveConfig { constructor(props) { Object.assign(this, { ...props }); } } exports.MysqlSlaveConfig = MysqlSlaveConfig; __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlSlaveConfig.prototype, "host", void 0); __decorate([ (0, utils_1.IsInt)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", Number) ], MysqlSlaveConfig.prototype, "port", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlSlaveConfig.prototype, "username", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlSlaveConfig.prototype, "password", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlSlaveConfig.prototype, "database", void 0); var Dialect; (function (Dialect) { Dialect["MYSQL"] = "mysql"; Dialect["POSTGRES"] = "postgres"; Dialect["COCKROACHDB"] = "cockroachdb"; Dialect["SAP"] = "sap"; Dialect["MARIADB"] = "mariadb"; Dialect["SQLITE"] = "sqlite"; Dialect["CORDOVA"] = "cordova"; Dialect["REACT_NATIVE"] = "react-native"; Dialect["NATIVESCRIPT"] = "nativescript"; Dialect["SQLJS"] = "sqljs"; Dialect["ORACLE"] = "oracle"; Dialect["MSSQL"] = "mssql"; Dialect["MONGODB"] = "mongodb"; Dialect["AURORA_MYSQL"] = "aurora-mysql"; Dialect["AURORA_POSTGRES"] = "aurora-postgres"; Dialect["EXPO"] = "expo"; Dialect["BETTER_SQLITE3"] = "better-sqlite3"; Dialect["CAPACITOR"] = "capacitor"; Dialect["SPANNER"] = "spanner"; })(Dialect || (exports.Dialect = Dialect = {})); var MysqlLogLevel; (function (MysqlLogLevel) { MysqlLogLevel["query"] = "query"; MysqlLogLevel["schema"] = "schema"; MysqlLogLevel["error"] = "error"; MysqlLogLevel["warn"] = "warn"; MysqlLogLevel["info"] = "info"; MysqlLogLevel["log"] = "log"; MysqlLogLevel["migration"] = "migration"; })(MysqlLogLevel || (exports.MysqlLogLevel = MysqlLogLevel = {})); class MysqlBenchmarkConfig { constructor(props) { this.enable = false; this.all = false; this.level = []; Object.assign(this, props); } } exports.MysqlBenchmarkConfig = MysqlBenchmarkConfig; __decorate([ (0, utils_1.IsOptional)(), (0, utils_1.IsBoolean)(), __metadata("design:type", Boolean) ], MysqlBenchmarkConfig.prototype, "enable", void 0); __decorate([ (0, utils_1.IsOptional)(), (0, utils_1.IsBoolean)(), __metadata("design:type", Boolean) ], MysqlBenchmarkConfig.prototype, "all", void 0); __decorate([ (0, utils_1.IsOptional)(), (0, utils_1.IsArray)(), (0, utils_1.IsEnum)(MysqlLogLevel, { each: true }), __metadata("design:type", Array) ], MysqlBenchmarkConfig.prototype, "level", void 0); class MysqlConfig extends core_1.ClientConfig { constructor(props) { super(props); this.dialect = Dialect.MYSQL; this.host = 'localhost'; this.port = 3306; this.connectTimeout = 20000; this.slaves = []; this.sync = true; Object.assign(this, { ...props, benchmark: new MysqlBenchmarkConfig(props?.benchmark), }); if (props?.slaves?.length) { const masterConfig = (0, lodash_1.pick)(props, ['host', 'port', 'username', 'password', 'database']); this.slaves = props.slaves.map(slave => new MysqlSlaveConfig({ ...masterConfig, ...slave })); } } } exports.MysqlConfig = MysqlConfig; __decorate([ (0, utils_1.IsEnum)(Dialect), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlConfig.prototype, "dialect", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlConfig.prototype, "host", void 0); __decorate([ (0, utils_1.IsInt)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", Number) ], MysqlConfig.prototype, "port", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlConfig.prototype, "username", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlConfig.prototype, "password", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsNotEmpty)(), __metadata("design:type", String) ], MysqlConfig.prototype, "database", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsOptional)(), __metadata("design:type", String) ], MysqlConfig.prototype, "charset", void 0); __decorate([ (0, utils_1.IsString)(), (0, utils_1.IsOptional)(), __metadata("design:type", String) ], MysqlConfig.prototype, "timezone", void 0); __decorate([ (0, utils_1.IsInt)(), (0, utils_1.IsOptional)(), __metadata("design:type", Number) ], MysqlConfig.prototype, "connectTimeout", void 0); __decorate([ (0, utils_1.IsArray)(), (0, utils_1.IsTypes)(MysqlSlaveConfig, { each: true }), (0, utils_1.IsOptional)(), __metadata("design:type", Array) ], MysqlConfig.prototype, "slaves", void 0); __decorate([ (0, utils_1.IsOptional)(), (0, utils_1.IsBoolean)(), __metadata("design:type", Boolean) ], MysqlConfig.prototype, "sync", void 0); __decorate([ (0, utils_1.IsOptional)(), (0, utils_1.IsTypes)(MysqlBenchmarkConfig), __metadata("design:type", MysqlBenchmarkConfig) ], MysqlConfig.prototype, "benchmark", void 0); //# sourceMappingURL=mysql.config.js.map