| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216 |
- using Azylee.Core.AppUtils.AppConfigUtils.AppConfigInterfaces;
- using Azylee.Core.DataUtils.EncryptUtils;
- using Azylee.Core.DataUtils.StringUtils;
- using Azylee.Core.DbUtils;
- using Azylee.Core.DbUtils.DbModels;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- namespace Azylee.Core.AppUtils.AppConfigUtils.AppConfigModels
- {
- /// <summary>
- /// 数据库配置信息
- /// </summary>
- public class AppConfigDbItem : IAppConfigItemModel
- {
- private string PASSWORD_ENC_SIGN = "ENC:::";
- private string PASSWORD_ENC_PWD = "app.db.pwd.20211202";
- /// <summary>
- /// 序号
- /// </summary>
- public int Number { get; set; }
- /// <summary>
- /// 唯一名称
- /// </summary>
- public string Name { get; set; }
- /// <summary>
- /// 服务器IP地址
- /// </summary>
- public string Server { get; set; }
- /// <summary>
- /// 服务器端口号
- /// </summary>
- public string Port { get; set; }
- /// <summary>
- /// 登录用户ID
- /// </summary>
- public string UserId { get; set; }
- /// <summary>
- /// 登录用户密码
- /// </summary>
- public string Password { get; set; }
- public void SetPasswordEnc(string value)
- {
- if (Str.Ok(value) && !value.StartsWith(PASSWORD_ENC_SIGN))
- {
- Password = PASSWORD_ENC_SIGN + AesTool.Encrypt(value, PASSWORD_ENC_PWD);
- }
- else
- {
- Password = value ?? "";
- }
- }
- public string GetPasswordEnc()
- {
- if (Str.Ok(Password) && Password.StartsWith(PASSWORD_ENC_SIGN))
- {
- return AesTool.Decrypt(Password.Substring(PASSWORD_ENC_SIGN.Length), PASSWORD_ENC_PWD);
- }
- else
- {
- return Password;
- }
- }
- /// <summary>
- /// 数据库类型
- /// </summary>
- public string Type { get; set; }
- /// <summary>
- /// 默认数据库
- /// </summary>
- public string Database { get; set; }
- /// <summary>
- /// 扩展连接字符串
- /// </summary>
- public string ExtConnectString { get; set; }
- /// <summary>
- /// 描述信息
- /// </summary>
- public string Desc { get; set; }
- /// <summary>
- /// 全参数构造函数
- /// </summary>
- /// <param name="number"></param>
- /// <param name="type"></param>
- /// <param name="name"></param>
- /// <param name="server"></param>
- /// <param name="port"></param>
- /// <param name="userid"></param>
- /// <param name="password"></param>
- /// <param name="database"></param>
- /// <param name="extConnectString"></param>
- /// <param name="desc"></param>
- public AppConfigDbItem(int number, string type, string name, string server, string port, string userid, string password, string database, string extConnectString, string desc)
- {
- Number = number;
- Type = type;
- Name = name;
- Server = server;
- Port = port;
- UserId = userid;
- SetPasswordEnc(password);
- Database = database;
- ExtConnectString = extConnectString;
- Desc = desc;
- }
- public DatabaseType DbType()
- {
- switch (Type.ToLower())
- {
- case "pg":
- case "postgresql": return DatabaseType.PostgreSQL;
- case "mysql":
- default:
- return DatabaseType.Mysql;
- }
- }
- /// <summary>
- /// 连接字符串
- /// </summary>
- /// <param name="database">执行连接库</param>
- /// <returns></returns>
- public string ConnectionString(string database = null)
- {
- if (!Str.Ok(database)) database = Database;
- switch (DbType())
- {
- case DatabaseType.PostgreSQL:
- {
- return $"Server = {Server}; Port = {(Str.Ok(Port) ? Port : "3306")}; User Id = {UserId}; Password = {GetPasswordEnc()}; Database = {database}; {ExtConnectString}";
- }
- case DatabaseType.Mysql:
- default:
- {
- return $"server = {Server}; port = {(Str.Ok(Port) ? Port : "3306")}; userid = {UserId}; password = {GetPasswordEnc()}; database = {database}; persistsecurityinfo = True; {ExtConnectString}";
- }
- }
- }
- /// <summary>
- /// 表空间配置库
- /// </summary>
- /// <returns></returns>
- public string SchemaDatabase()
- {
- switch (DbType())
- {
- case DatabaseType.PostgreSQL:
- {
- return "";
- }
- case DatabaseType.Mysql:
- default:
- {
- return "information_schema";
- }
- }
- }
- /// <summary>
- /// 测试连接查询语句
- /// </summary>
- /// <returns></returns>
- public string ValidationQuery()
- {
- switch (DbType())
- {
- case DatabaseType.PostgreSQL:
- case DatabaseType.Mysql:
- default:
- {
- return "select now()";
- }
- }
- }
- /// <summary>
- /// 表空间查询语句
- /// </summary>
- /// <returns></returns>
- public string SchemaQuery()
- {
- switch (DbType())
- {
- case DatabaseType.PostgreSQL:
- return "SELECT datname AS schema_name FROM pg_database";
- case DatabaseType.Mysql:
- default:
- return "SELECT schema_name FROM `SCHEMATA`";
- }
- }
- /// <summary>
- /// 排序序号
- /// </summary>
- /// <returns></returns>
- public int GetOrderNumber()
- {
- return this.Number;
- }
- /// <summary>
- /// 唯一名称
- /// </summary>
- /// <returns></returns>
- public string GetUniqueName()
- {
- return this.Name;
- }
- }
- }
|