exodus-framework 2.0.727 → 2.0.730

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.
@@ -15,10 +15,11 @@ class DatabaseController extends _app.MessagingController {
15
15
  (0, _utils.logger)().error(data, 'Não foi possível criar o banco de dados');
16
16
  return this.log('Não foi possível criar um banco de dados', 'danger');
17
17
  }
18
- ack();
19
18
  } catch (error) {
20
19
  (0, _utils.logger)().error(error);
21
20
  this.log('Houve um erro ao tentar criar um banco de dados, check o log...', 'danger');
21
+ } finally {
22
+ ack();
22
23
  }
23
24
  };
24
25
  update = async (data, ack) => {
@@ -29,10 +30,11 @@ class DatabaseController extends _app.MessagingController {
29
30
  return this.log('Não foi possível atualizar um banco de dados. Banco não encontrado', 'danger');
30
31
  }
31
32
  await host.update(data.updated);
32
- ack();
33
33
  } catch (error) {
34
34
  (0, _utils.logger)().error(error);
35
35
  this.log('Houve um erro ao tentar atualizar um banco de dados, check o log...', 'danger');
36
+ } finally {
37
+ ack();
36
38
  }
37
39
  };
38
40
  delete = async (data, ack) => {
@@ -43,10 +45,11 @@ class DatabaseController extends _app.MessagingController {
43
45
  return this.log('Não foi possível excluír um banco de dados. Banco não encontrado', 'danger');
44
46
  }
45
47
  await host.destroy();
46
- ack();
47
48
  } catch (error) {
48
49
  (0, _utils.logger)().error(error);
49
50
  this.log('Houve um erro ao tentar excluír um banco de dados, check o log...', 'danger');
51
+ } finally {
52
+ ack();
50
53
  }
51
54
  };
52
55
  }
@@ -1 +1 @@
1
- {"version":3,"file":"environment.d.ts","sourceRoot":"","sources":["../../../src/controllers/messaging/environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAI1E,cAAM,qBAAsB,SAAQ,mBAAmB;IACrD,OAAO,EAAE,sBAAsB,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAuBjE;IAEF,OAAO,EAAE,sBAAsB,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAmBjE;IASF,eAAe,EAAE,sBAAsB,CAAC,eAAe,CAAC,0BAA0B,CAAC,CAwBjF;CACH;AAED,eAAe,qBAAqB,CAAC"}
1
+ {"version":3,"file":"environment.d.ts","sourceRoot":"","sources":["../../../src/controllers/messaging/environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAI1E,cAAM,qBAAsB,SAAQ,mBAAmB;IACrD,OAAO,EAAE,sBAAsB,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAkBjE;IAEF,OAAO,EAAE,sBAAsB,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAoBjE;IAEF,eAAe,EAAE,sBAAsB,CAAC,eAAe,CAAC,0BAA0B,CAAC,CAyBjF;CACH;AAED,eAAe,qBAAqB,CAAC"}
@@ -11,20 +11,19 @@ class EnvironmentController extends _app.MessagingController {
11
11
  created = async (data, ack) => {
12
12
  const db = data.database;
13
13
  const token = data.envToken;
14
- _services.SequelizeService.singleton().createDB(db, token).then(() => {
15
- _models.EnvDBHost.create({
14
+ try {
15
+ await _services.SequelizeService.singleton().createDB(db, token);
16
+ await _models.EnvDBHost.create({
16
17
  envUuid: data.uuid,
17
18
  hostUuid: data.database,
18
19
  envToken: data.envToken
19
- }).then(() => {
20
- this.log(`New database created sucessfuly: ${db}`);
21
- ack();
22
- }).catch(error => {
23
- new _services.ApplicationException('Erro ao criar a relação env-db', error);
24
20
  });
25
- }).catch(error => {
26
- new _services.ApplicationException('Erro ao criar o novo banco de dados', error);
27
- });
21
+ this.log(`New database created successfully: ${db}`);
22
+ } catch (error) {
23
+ throw new _services.ApplicationException('Erro ao criar o novo banco de dados', error);
24
+ } finally {
25
+ ack();
26
+ }
28
27
  };
29
28
  deleted = async (data, ack) => {
30
29
  // const uuid = data.uuid;
@@ -39,19 +38,12 @@ class EnvironmentController extends _app.MessagingController {
39
38
  });
40
39
  if (relation) await relation.destroy();
41
40
  this.log(`Database deleted successfully: ${token}`);
42
- ack();
43
41
  } catch (error) {
44
42
  throw new _services.ApplicationException('Erro ao deletar a relação env-db ou não foi possível encontrá-la', error);
43
+ } finally {
44
+ ack();
45
45
  }
46
46
  };
47
-
48
- /* updatedToken: TMessagingQueueHandler<EMessagingQueue.environmentUpdatedToken> = async (
49
- data,
50
- ack
51
- ) => {
52
- //TODO: need implement
53
- }; */
54
-
55
47
  updatedDatabase = async (data, ack) => {
56
48
  try {
57
49
  const relation = await _models.EnvDBHost.findOne({
@@ -66,9 +58,10 @@ class EnvironmentController extends _app.MessagingController {
66
58
  hostUuid: data.database
67
59
  });
68
60
  this.log(`A relação para o ambiente ${data.envUuid} foi atualizada, a migração deverá ser realizada de forma manual`);
69
- ack();
70
61
  } catch (error) {
71
62
  new _services.ApplicationException('Erro ao atualizar a relação EDB', error);
63
+ } finally {
64
+ ack();
72
65
  }
73
66
  };
74
67
  }
@@ -11,7 +11,7 @@ exports.Application = Application;
11
11
  Application.init({
12
12
  uuid: {
13
13
  type: _sequelize.DataTypes.UUID,
14
- defaultValue: _sequelize.DataTypes.UUIDV4,
14
+ // defaultValue: DataTypes.UUIDV4, //pode ser arbritário
15
15
  primaryKey: true,
16
16
  allowNull: false,
17
17
  autoIncrement: false
@@ -11,7 +11,7 @@ exports.DatabaseHost = DatabaseHost;
11
11
  DatabaseHost.init({
12
12
  uuid: {
13
13
  type: _sequelize.DataTypes.UUID,
14
- defaultValue: _sequelize.DataTypes.UUIDV4,
14
+ // defaultValue: DataTypes.UUIDV4,//pode ser arbritário
15
15
  primaryKey: true,
16
16
  allowNull: false,
17
17
  autoIncrement: false
@@ -53,6 +53,10 @@ DatabaseHost.init({
53
53
  tableName: 'database_hosts',
54
54
  sequelize: _database.serviceDB,
55
55
  indexes: [{
56
- fields: ['name']
56
+ fields: ['name'],
57
+ unique: true
58
+ }, {
59
+ fields: ['host'],
60
+ unique: true
57
61
  }]
58
62
  });
@@ -11,7 +11,7 @@ exports.EnvDBHost = EnvDBHost;
11
11
  EnvDBHost.init({
12
12
  uuid: {
13
13
  type: _sequelize.DataTypes.UUID,
14
- defaultValue: _sequelize.DataTypes.UUIDV4,
14
+ // defaultValue: DataTypes.UUIDV4,//pode ser arbritário
15
15
  primaryKey: true,
16
16
  allowNull: false,
17
17
  autoIncrement: false
@@ -1,4 +1,4 @@
1
- import { Model, ModelStatic, Sequelize } from 'sequelize';
1
+ import { Dialect, Model, ModelStatic, Sequelize } from 'sequelize';
2
2
  import Service from '../app/service';
3
3
  import { IService } from '../contracts/service';
4
4
  import { EnvDBHost } from '../models';
@@ -19,7 +19,13 @@ declare class SequelizeService extends Service implements IService {
19
19
  getDBName(envToken: string): string;
20
20
  reconnect(db: Sequelize, attempts?: number): void;
21
21
  createConnection(hostUuid: string, database?: string): Promise<false | Sequelize>;
22
- testConnection(host: string, port: number, username: string, password: string): Promise<boolean>;
22
+ testConnection(data: {
23
+ host: string;
24
+ port: number;
25
+ username: string;
26
+ password: string;
27
+ dialect: Dialect;
28
+ }): Promise<boolean>;
23
29
  getRelation(tenantId: string): Promise<EnvDBHost>;
24
30
  getModel<M extends typeof Model<any, any>>(model: typeof Model<any, any> & {
25
31
  initialize: (connection: Sequelize) => M;
@@ -1 +1 @@
1
- {"version":3,"file":"sequelize.d.ts","sourceRoot":"","sources":["../../src/services/sequelize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAE1D,OAAO,OAAO,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAgB,MAAM,WAAW,CAAC;AAcpD,cAAM,gBAAiB,SAAQ,OAAQ,YAAW,QAAQ;IACxD,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;IAC3B,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACvD,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;;IAM5B,IAAI;IAQJ,gBAAgB;IAgChB,KAAK,CAAC,QAAQ,EAAE,MAAM;IActB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IA6BvC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAiBvC,MAAM,CAAC,QAAQ,EAAE,MAAM;IAiB7B,SAAS,CAAC,QAAQ,EAAE,MAAM;IAK1B,SAAS,CAAC,EAAE,EAAE,SAAS,EAAE,QAAQ,SAAI;IAe/B,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM;IA6CpD,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM;IA4B7E,WAAW,CAAC,QAAQ,EAAE,MAAM;IAe5B,QAAQ,CAAC,CAAC,SAAS,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,EAC7C,KAAK,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG;QAAE,UAAU,EAAE,CAAC,UAAU,EAAE,SAAS,KAAK,CAAC,CAAA;KAAE,EAC5E,QAAQ,EAAE,MAAM;IA2BlB,cAAc,CAAC,MAAM,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE;CAG1C;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"sequelize.d.ts","sourceRoot":"","sources":["../../src/services/sequelize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEnE,OAAO,OAAO,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAgB,MAAM,WAAW,CAAC;AAcpD,cAAM,gBAAiB,SAAQ,OAAQ,YAAW,QAAQ;IACxD,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;IAC3B,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACvD,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;;IAM5B,IAAI;IAQJ,gBAAgB;IAgChB,KAAK,CAAC,QAAQ,EAAE,MAAM;IActB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IA6BvC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAiBvC,MAAM,CAAC,QAAQ,EAAE,MAAM;IAiB7B,SAAS,CAAC,QAAQ,EAAE,MAAM;IAK1B,SAAS,CAAC,EAAE,EAAE,SAAS,EAAE,QAAQ,SAAI;IAe/B,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM;IA6CpD,cAAc,CAAC,IAAI,EAAE;QACzB,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,OAAO,CAAC;KAClB;IA6BK,WAAW,CAAC,QAAQ,EAAE,MAAM;IAe5B,QAAQ,CAAC,CAAC,SAAS,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,EAC7C,KAAK,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG;QAAE,UAAU,EAAE,CAAC,UAAU,EAAE,SAAS,KAAK,CAAC,CAAA;KAAE,EAC5E,QAAQ,EAAE,MAAM;IA2BlB,cAAc,CAAC,MAAM,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE;CAG1C;AAED,eAAe,gBAAgB,CAAC"}
@@ -190,12 +190,13 @@ class SequelizeService extends _service.default {
190
190
  });
191
191
  });
192
192
  }
193
- async testConnection(host, port, username, password) {
193
+ async testConnection(data) {
194
194
  const sequelize = new _sequelize.Sequelize({
195
- host,
196
- port,
197
- username,
198
- password,
195
+ host: data.host,
196
+ port: data.port,
197
+ username: data.username,
198
+ password: data.password,
199
+ dialect: data.dialect,
199
200
  timezone: '-03:00',
200
201
  logging(sql, timing) {
201
202
  (0, _logger.default)().trace('DATABASE', sql, timing);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "exodus-framework",
3
- "version": "2.0.727",
3
+ "version": "2.0.730",
4
4
  "description": "Exodus Framework",
5
5
  "author": "jhownpaixao",
6
6
  "license": "ISC",