@joktec/mysql
Version:
JokTec - MySql Service
185 lines • 6.74 kB
JavaScript
;
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