@gugananuvem/aws-local-simulator 1.0.12 → 1.0.15

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.
Files changed (77) hide show
  1. package/README.md +594 -257
  2. package/bin/aws-local-simulator.js +63 -63
  3. package/package.json +21 -10
  4. package/src/config/config-loader.js +114 -114
  5. package/src/config/default-config.js +68 -67
  6. package/src/config/env-loader.js +68 -68
  7. package/src/index.js +146 -130
  8. package/src/index.mjs +123 -123
  9. package/src/server.js +227 -223
  10. package/src/services/apigateway/index.js +73 -68
  11. package/src/services/apigateway/server.js +507 -487
  12. package/src/services/apigateway/simulator.js +1261 -1251
  13. package/src/services/athena/index.js +75 -0
  14. package/src/services/athena/server.js +101 -0
  15. package/src/services/athena/simulador.js +998 -0
  16. package/src/services/athena/simulator.js +346 -0
  17. package/src/services/cloudformation/index.js +106 -0
  18. package/src/services/cloudformation/server.js +417 -0
  19. package/src/services/cloudformation/simulador.js +1045 -0
  20. package/src/services/cloudtrail/index.js +84 -0
  21. package/src/services/cloudtrail/server.js +235 -0
  22. package/src/services/cloudtrail/simulador.js +719 -0
  23. package/src/services/cloudwatch/index.js +84 -0
  24. package/src/services/cloudwatch/server.js +366 -0
  25. package/src/services/cloudwatch/simulador.js +1173 -0
  26. package/src/services/cognito/index.js +79 -65
  27. package/src/services/cognito/server.js +301 -279
  28. package/src/services/cognito/simulator.js +1655 -1115
  29. package/src/services/config/index.js +96 -0
  30. package/src/services/config/server.js +215 -0
  31. package/src/services/config/simulador.js +1260 -0
  32. package/src/services/dynamodb/index.js +74 -70
  33. package/src/services/dynamodb/server.js +125 -121
  34. package/src/services/dynamodb/simulator.js +630 -620
  35. package/src/services/ecs/index.js +65 -65
  36. package/src/services/ecs/server.js +235 -233
  37. package/src/services/ecs/simulator.js +844 -844
  38. package/src/services/eventbridge/index.js +89 -85
  39. package/src/services/eventbridge/server.js +209 -0
  40. package/src/services/eventbridge/simulator.js +684 -0
  41. package/src/services/index.js +45 -19
  42. package/src/services/kms/index.js +75 -0
  43. package/src/services/kms/server.js +67 -0
  44. package/src/services/kms/simulator.js +324 -0
  45. package/src/services/lambda/handler-loader.js +183 -183
  46. package/src/services/lambda/index.js +78 -73
  47. package/src/services/lambda/route-registry.js +274 -274
  48. package/src/services/lambda/server.js +145 -145
  49. package/src/services/lambda/simulator.js +199 -172
  50. package/src/services/parameter-store/index.js +80 -0
  51. package/src/services/parameter-store/server.js +50 -0
  52. package/src/services/parameter-store/simulator.js +201 -0
  53. package/src/services/s3/index.js +73 -69
  54. package/src/services/s3/server.js +329 -238
  55. package/src/services/s3/simulator.js +565 -740
  56. package/src/services/secret-manager/index.js +80 -0
  57. package/src/services/secret-manager/server.js +50 -0
  58. package/src/services/secret-manager/simulator.js +171 -0
  59. package/src/services/sns/index.js +89 -76
  60. package/src/services/sns/server.js +580 -0
  61. package/src/services/sns/simulator.js +1482 -0
  62. package/src/services/sqs/index.js +93 -95
  63. package/src/services/sqs/server.js +349 -345
  64. package/src/services/sqs/simulator.js +441 -441
  65. package/src/services/sts/index.js +37 -37
  66. package/src/services/sts/server.js +144 -142
  67. package/src/services/sts/simulator.js +69 -69
  68. package/src/services/xray/index.js +83 -0
  69. package/src/services/xray/server.js +308 -0
  70. package/src/services/xray/simulador.js +994 -0
  71. package/src/template/aws-config-template.js +87 -87
  72. package/src/template/aws-config-template.mjs +90 -90
  73. package/src/template/config-template.json +203 -203
  74. package/src/utils/aws-config.js +91 -91
  75. package/src/utils/cloudtrail-audit.js +129 -0
  76. package/src/utils/local-store.js +83 -67
  77. package/src/utils/logger.js +59 -59
package/src/server.js CHANGED
@@ -1,223 +1,227 @@
1
- /**
2
- * Servidor Principal - Orquestra todos os serviços
3
- */
4
-
5
- const path = require("path");
6
- const fs = require("fs");
7
- const mkdirp = require("mkdirp");
8
- const logger = require("./utils/logger");
9
-
10
- // Importa serviços
11
- const DynamoDBService = require("./services/dynamodb");
12
- const S3Service = require("./services/s3");
13
- const SQSService = require("./services/sqs");
14
- const LambdaService = require("./services/lambda");
15
- const SNSService = require("./services/sns");
16
- const EventBridgeService = require("./services/eventbridge");
17
- const CognitoService = require("./services/cognito");
18
- const APIGatewayService = require("./services/apigateway");
19
- const ECSService = require("./services/ecs");
20
- const STSService = require("./services/sts");
21
-
22
- class Server {
23
- constructor(config) {
24
- this.config = config;
25
- this.services = [];
26
- this.servicesMap = new Map();
27
- this.running = false;
28
- this.setupDataDir();
29
- this.setupLogLevel();
30
- }
31
-
32
- setupDataDir() {
33
- const dataDir = path.resolve(process.cwd(), this.config.dataDir);
34
- if (!fs.existsSync(dataDir)) {
35
- mkdirp.sync(dataDir);
36
- logger.debug(`📁 Diretório de dados criado: ${dataDir}`);
37
- }
38
- process.env.AWS_LOCAL_SIMULATOR_DATA_DIR = dataDir;
39
- }
40
-
41
- setupLogLevel() {
42
- logger.setLevel(this.config.logLevel);
43
- logger.info(`📝 Nível de log: ${this.config.logLevel}`);
44
- }
45
-
46
- async start() {
47
- if (this.running) {
48
- logger.warn("Servidor já está rodando");
49
- return;
50
- }
51
-
52
- logger.info("\n🚀 Iniciando AWS Local Simulator...\n");
53
-
54
- try {
55
- await this.initializeServices();
56
- await this.startServices();
57
-
58
- this.running = true;
59
- this.printStatus();
60
- } catch (error) {
61
- logger.error(" Erro ao iniciar servidor:", error);
62
- throw error;
63
- }
64
- }
65
-
66
- async initializeServices() {
67
- // Ordem de inicialização importante
68
- const serviceOrder = [
69
- { name: "sts", class: STSService, depends: [] },
70
- { name: "lambda", class: LambdaService, depends: [] },
71
- { name: "dynamodb", class: DynamoDBService, depends: [] },
72
- { name: "s3", class: S3Service, depends: [] },
73
- { name: "sqs", class: SQSService, depends: ["lambda"] },
74
- { name: "sns", class: SNSService, depends: [] },
75
- { name: "eventbridge", class: EventBridgeService, depends: [] },
76
- { name: "cognito", class: CognitoService, depends: [] },
77
- { name: "ecs", class: ECSService, depends: [] },
78
- { name: "apigateway", class: APIGatewayService, depends: ["lambda"] },
79
- ];
80
-
81
- for (const serviceDef of serviceOrder) {
82
- if (this.config.services[serviceDef.name]) {
83
- try {
84
- // Resolve dependências
85
- const dependencies = {};
86
- for (const dep of serviceDef.depends) {
87
- dependencies[dep] = this.servicesMap.get(dep);
88
- }
89
-
90
- const service = new serviceDef.class(this.config, dependencies);
91
- await service.initialize();
92
-
93
- this.services.push(service);
94
- this.servicesMap.set(serviceDef.name, service);
95
-
96
- logger.success(`✅ ${serviceDef.name.toUpperCase()} Service inicializado`);
97
- } catch (error) {
98
- logger.error(`❌ Erro ao inicializar ${serviceDef.name}:`, error);
99
- if (serviceDef.name === "lambda") {
100
- throw error; // Lambda é essencial
101
- }
102
- }
103
- }
104
- }
105
-
106
- /*
107
- // Cognito Service (opcional)
108
- if (this.config.services.cognito) {
109
- const cognitoService = new CognitoService(this.config);
110
- await cognitoService.initialize();
111
- this.services.push(cognitoService);
112
- this.servicesMap.set("cognito", cognitoService);
113
- logger.success("✅ Cognito Service inicializado");
114
- }
115
- if (this.config.services.apigateway) {
116
- const apigatewayService = new APIGatewayService(this.config);
117
- await apigatewayService.initialize();
118
- this.services.push(apigatewayService);
119
- this.servicesMap.set("apigateway", apigatewayService);
120
- logger.success("✅ API Gateway Service inicializado");
121
- }*/
122
- }
123
-
124
- async startServices() {
125
- const startPromises = this.services.map((service) => service.start());
126
- await Promise.all(startPromises);
127
- logger.success("\n🎉 Todos os serviços foram iniciados com sucesso!");
128
- }
129
-
130
- async stop() {
131
- if (!this.running) {
132
- logger.warn("Servidor não está rodando");
133
- return;
134
- }
135
-
136
- logger.info("\n🛑 Parando AWS Local Simulator...\n");
137
-
138
- try {
139
- const stopPromises = [...this.services].reverse().map((service) => service.stop());
140
- await Promise.all(stopPromises);
141
-
142
- this.running = false;
143
- logger.success("✅ Todos os serviços foram parados");
144
- } catch (error) {
145
- logger.error("❌ Erro ao parar servidor:", error);
146
- throw error;
147
- }
148
- }
149
-
150
- async reset() {
151
- logger.info("\n🗑️ Resetando todos os dados...\n");
152
-
153
- const resetPromises = this.services.map((service) => service.reset());
154
- await Promise.all(resetPromises);
155
-
156
- logger.success("✅ Todos os dados foram resetados");
157
- }
158
-
159
- getStatus() {
160
- const status = {
161
- running: this.running,
162
- services: {},
163
- };
164
-
165
- for (const service of this.services) {
166
- status.services[service.name] = service.getStatus();
167
- }
168
-
169
- return status;
170
- }
171
-
172
- getService(name) {
173
- return this.servicesMap.get(name);
174
- }
175
-
176
- printStatus() {
177
- logger.info("\n" + "=".repeat(60));
178
- logger.info("📊 Status dos Serviços:");
179
- logger.info("=".repeat(60));
180
-
181
- for (const service of this.services) {
182
- const status = service.getStatus();
183
- logger.info(`\n${service.name.toUpperCase()}:`);
184
- logger.info(` Status: ${status.running ? "✅ Rodando" : "❌ Parado"}`);
185
- logger.info(` Porta: ${status.port}`);
186
- logger.info(` Endpoint: ${status.endpoint}`);
187
-
188
- if (status.tablesCount !== undefined) {
189
- logger.info(` Tabelas: ${status.tablesCount}`);
190
- }
191
- if (status.bucketsCount !== undefined) {
192
- logger.info(` Buckets: ${status.bucketsCount}`);
193
- }
194
- if (status.queuesCount !== undefined) {
195
- logger.info(` Filas: ${status.queuesCount}`);
196
- }
197
- if (status.lambdasCount !== undefined) {
198
- logger.info(` Lambdas: ${status.lambdasCount}`);
199
- }
200
- if (status.objectsCount !== undefined) {
201
- logger.info(` Objetos: ${status.objectsCount}`);
202
- }
203
- if (status.messagesCount !== undefined) {
204
- logger.info(` Mensagens: ${status.messagesCount}`);
205
- }
206
- }
207
-
208
- logger.info("\n" + "=".repeat(60));
209
- logger.info("\n📝 Comandos úteis:");
210
- logger.info(" AWS CLI:");
211
- logger.info(" aws dynamodb list-tables --endpoint-url http://localhost:8000");
212
- logger.info(" aws s3 ls --endpoint-url http://localhost:4566");
213
- logger.info(" aws sqs list-queues --endpoint-url http://localhost:9324");
214
- logger.info("\n Testar APIs:");
215
- logger.info(" curl http://localhost:3001/health");
216
- logger.info(" curl http://localhost:8000/__admin/tables");
217
- logger.info(" curl http://localhost:4566/__admin/buckets");
218
- logger.info(" curl http://localhost:9324/__admin/queues");
219
- logger.info("=".repeat(60) + "\n");
220
- }
221
- }
222
-
223
- module.exports = Server;
1
+ /**
2
+ * Servidor Principal - Orquestra todos os serviços
3
+ */
4
+
5
+ const path = require("path");
6
+ const fs = require("fs");
7
+ const mkdirp = require("mkdirp");
8
+ const logger = require("./utils/logger");
9
+
10
+ // Importa serviços
11
+ const DynamoDBService = require("./services/dynamodb");
12
+ const S3Service = require("./services/s3");
13
+ const SQSService = require("./services/sqs");
14
+ const LambdaService = require("./services/lambda");
15
+ const { SNSService } = require("./services/sns");
16
+ const { EventBridgeService } = require("./services/eventbridge");
17
+ const CognitoService = require("./services/cognito");
18
+ const APIGatewayService = require("./services/apigateway");
19
+ const ECSService = require("./services/ecs");
20
+ const STSService = require("./services/sts");
21
+ const { CloudWatchService } = require("./services/cloudwatch");
22
+ const CloudTrailService = require("./services/cloudtrail");
23
+ const { KMSService } = require("./services/kms");
24
+ const CloudFormationService = require("./services/cloudformation");
25
+ const { XRayService } = require("./services/xray");
26
+ const { SecretManagerService } = require("./services/secret-manager");
27
+ const { ParameterStoreService } = require("./services/parameter-store");
28
+ const { ConfigService } = require("./services/config");
29
+ const { AthenaService } = require("./services/athena");
30
+
31
+ class Server {
32
+ constructor(config) {
33
+ this.config = config;
34
+ this.services = [];
35
+ this.servicesMap = new Map();
36
+ this.running = false;
37
+ this.setupDataDir();
38
+ this.setupLogLevel();
39
+ }
40
+
41
+ setupDataDir() {
42
+ const dataDir = path.resolve(process.cwd(), this.config.dataDir);
43
+ if (!fs.existsSync(dataDir)) {
44
+ mkdirp.sync(dataDir);
45
+ logger.debug(`📁 Diretório de dados criado: ${dataDir}`);
46
+ }
47
+ process.env.AWS_LOCAL_SIMULATOR_DATA_DIR = dataDir;
48
+ }
49
+
50
+ setupLogLevel() {
51
+ logger.setLevel(this.config.logLevel);
52
+ logger.info(`📝 Nível de log: ${this.config.logLevel}`);
53
+ }
54
+
55
+ async start() {
56
+ if (this.running) {
57
+ logger.warn("Servidor já está rodando");
58
+ return;
59
+ }
60
+
61
+ logger.info("\n🚀 Iniciando AWS Local Simulator...\n");
62
+
63
+ try {
64
+ await this.initializeServices();
65
+ await this.startServices();
66
+
67
+ this.running = true;
68
+ this.printStatus();
69
+ } catch (error) {
70
+ logger.error("❌ Erro ao iniciar servidor:", error);
71
+ throw error;
72
+ }
73
+ }
74
+
75
+ async initializeServices() {
76
+ const serviceOrder = [
77
+ { name: "sts", class: STSService, depends: [] },
78
+ { name: "lambda", class: LambdaService, depends: [] },
79
+ { name: "dynamodb", class: DynamoDBService, depends: [] },
80
+ { name: "s3", class: S3Service, depends: [] },
81
+ { name: "sqs", class: SQSService, depends: ["lambda"] },
82
+ { name: "sns", class: SNSService, depends: [] },
83
+ { name: "eventbridge", class: EventBridgeService, depends: [] },
84
+ { name: "cognito", class: CognitoService, depends: ["lambda"] },
85
+ { name: "ecs", class: ECSService, depends: [] },
86
+ { name: "apigateway", class: APIGatewayService, depends: ["lambda"] },
87
+ { name: "kms", class: KMSService, depends: [] },
88
+ { name: "cloudwatch", class: CloudWatchService, depends: [] },
89
+ { name: "cloudtrail", class: CloudTrailService, depends: [] },
90
+ { name: "cloudformation", class: CloudFormationService, depends: [] },
91
+ { name: "xray", class: XRayService, depends: [] },
92
+ { name: "secret-manager", class: SecretManagerService, depends: [] },
93
+ { name: "parameter-store",class: ParameterStoreService, depends: [] },
94
+ { name: "config", class: ConfigService, depends: [] },
95
+ { name: "athena", class: AthenaService, depends: [] },
96
+ ];
97
+
98
+ for (const serviceDef of serviceOrder) {
99
+ if (this.config.services[serviceDef.name]) {
100
+ try {
101
+ const dependencies = {};
102
+ for (const dep of serviceDef.depends) {
103
+ dependencies[dep] = this.servicesMap.get(dep);
104
+ }
105
+
106
+ const service = new serviceDef.class(this.config, dependencies);
107
+ await service.initialize();
108
+
109
+ this.services.push(service);
110
+ this.servicesMap.set(serviceDef.name, service);
111
+
112
+ logger.success(`✅ ${serviceDef.name.toUpperCase()} Service inicializado`);
113
+ } catch (error) {
114
+ logger.error(`❌ Erro ao inicializar ${serviceDef.name}:`, error);
115
+ if (serviceDef.name === "lambda") throw error;
116
+ }
117
+ }
118
+ }
119
+
120
+ // Injeta dependências cross-service nos serviços que suportam
121
+ for (const service of this.services) {
122
+ if (typeof service.injectDependencies === "function") {
123
+ service.injectDependencies(this);
124
+ }
125
+ }
126
+ }
127
+
128
+ async startServices() {
129
+ const startPromises = this.services.map((service) => service.start());
130
+ await Promise.all(startPromises);
131
+ logger.success("\n🎉 Todos os serviços foram iniciados com sucesso!");
132
+ }
133
+
134
+ async stop() {
135
+ if (!this.running) {
136
+ logger.warn("Servidor não está rodando");
137
+ return;
138
+ }
139
+
140
+ logger.info("\n🛑 Parando AWS Local Simulator...\n");
141
+
142
+ try {
143
+ const stopPromises = [...this.services].reverse().map((service) => service.stop());
144
+ await Promise.all(stopPromises);
145
+
146
+ this.running = false;
147
+ logger.success("✅ Todos os serviços foram parados");
148
+ } catch (error) {
149
+ logger.error("❌ Erro ao parar servidor:", error);
150
+ throw error;
151
+ }
152
+ }
153
+
154
+ async reset() {
155
+ logger.info("\n🗑️ Resetando todos os dados...\n");
156
+
157
+ const resetPromises = this.services.map((service) => service.reset());
158
+ await Promise.all(resetPromises);
159
+
160
+ logger.success("✅ Todos os dados foram resetados");
161
+ }
162
+
163
+ getStatus() {
164
+ const status = {
165
+ running: this.running,
166
+ services: {},
167
+ };
168
+
169
+ for (const service of this.services) {
170
+ status.services[service.name] = service.getStatus();
171
+ }
172
+
173
+ return status;
174
+ }
175
+
176
+ getService(name) {
177
+ return this.servicesMap.get(name);
178
+ }
179
+
180
+ printStatus() {
181
+ logger.info("\n" + "=".repeat(60));
182
+ logger.info("📊 Status dos Serviços:");
183
+ logger.info("=".repeat(60));
184
+
185
+ for (const service of this.services) {
186
+ const status = service.getStatus();
187
+ logger.info(`\n${service.name.toUpperCase()}:`);
188
+ logger.info(` Status: ${status.running ? "✅ Rodando" : "❌ Parado"}`);
189
+ logger.info(` Porta: ${status.port}`);
190
+ logger.info(` Endpoint: ${status.endpoint}`);
191
+
192
+ if (status.tablesCount !== undefined) {
193
+ logger.info(` Tabelas: ${status.tablesCount}`);
194
+ }
195
+ if (status.bucketsCount !== undefined) {
196
+ logger.info(` Buckets: ${status.bucketsCount}`);
197
+ }
198
+ if (status.queuesCount !== undefined) {
199
+ logger.info(` Filas: ${status.queuesCount}`);
200
+ }
201
+ if (status.lambdasCount !== undefined) {
202
+ logger.info(` Lambdas: ${status.lambdasCount}`);
203
+ }
204
+ if (status.objectsCount !== undefined) {
205
+ logger.info(` Objetos: ${status.objectsCount}`);
206
+ }
207
+ if (status.messagesCount !== undefined) {
208
+ logger.info(` Mensagens: ${status.messagesCount}`);
209
+ }
210
+ }
211
+
212
+ logger.info("\n" + "=".repeat(60));
213
+ logger.info("\n📝 Comandos úteis:");
214
+ logger.info(" AWS CLI:");
215
+ logger.info(" aws dynamodb list-tables --endpoint-url http://localhost:8000");
216
+ logger.info(" aws s3 ls --endpoint-url http://localhost:4566");
217
+ logger.info(" aws sqs list-queues --endpoint-url http://localhost:9324");
218
+ logger.info("\n Testar APIs:");
219
+ logger.info(" curl http://localhost:3001/health");
220
+ logger.info(" curl http://localhost:8000/__admin/tables");
221
+ logger.info(" curl http://localhost:4566/__admin/buckets");
222
+ logger.info(" curl http://localhost:9324/__admin/queues");
223
+ logger.info("=".repeat(60) + "\n");
224
+ }
225
+ }
226
+
227
+ module.exports = Server;
@@ -1,69 +1,74 @@
1
- /**
2
- * API Gateway Service - Simulador de Amazon API Gateway
3
- * Suporta: REST APIs, HTTP APIs, WebSocket APIs, Stages, Deployments
4
- */
5
-
6
- const APIGatewayServer = require('./server');
7
- const APIGatewaySimulator = require('./simulator');
8
-
9
- class APIGatewayService {
10
- constructor(config, dependencies = {}) {
11
- this.config = config;
12
- this.name = 'apigateway';
13
- this.port = config.ports.apigateway || 4567;
14
- this.server = null;
15
- this.simulator = null;
16
- this.isRunning = false;
17
- this.lambdaService = dependencies.lambda || null;
18
- }
19
-
20
- async initialize() {
21
- const logger = require('../../utils/logger');
22
- logger.debug(`Inicializando API Gateway Service na porta ${this.port}...`);
23
-
24
- this.simulator = new APIGatewaySimulator(this.config);
25
- await this.simulator.initialize();
26
-
27
- this.server = new APIGatewayServer(this.port, this.config);
28
- this.server.simulator = this.simulator;
29
- this.server.lambdaService = this.lambdaService;
30
-
31
- await this.server.initialize();
32
-
33
- logger.debug('API Gateway Service inicializado');
34
- }
35
-
36
- async start() {
37
- if (this.isRunning) return;
38
- await this.server.start();
39
- this.isRunning = true;
40
- }
41
-
42
- async stop() {
43
- if (!this.isRunning) return;
44
- await this.server.stop();
45
- this.isRunning = false;
46
- }
47
-
48
- async reset() {
49
- await this.simulator.reset();
50
- }
51
-
52
- getStatus() {
53
- return {
54
- running: this.isRunning,
55
- port: this.port,
56
- endpoint: `http://localhost:${this.port}`,
57
- apisCount: this.simulator?.getAPIsCount() || 0,
58
- deploymentsCount: this.simulator?.getDeploymentsCount() || 0,
59
- stagesCount: this.simulator?.getStagesCount() || 0,
60
- resourcesCount: this.simulator?.getResourcesCount() || 0
61
- };
62
- }
63
-
64
- getSimulator() {
65
- return this.simulator;
66
- }
67
- }
68
-
1
+ /**
2
+ * API Gateway Service - Simulador de Amazon API Gateway
3
+ * Suporta: REST APIs, HTTP APIs, WebSocket APIs, Stages, Deployments
4
+ */
5
+
6
+ const APIGatewayServer = require('./server');
7
+ const APIGatewaySimulator = require('./simulator');
8
+
9
+ class APIGatewayService {
10
+ constructor(config, dependencies = {}) {
11
+ this.config = config;
12
+ this.name = 'apigateway';
13
+ this.port = config.ports.apigateway || 4567;
14
+ this.server = null;
15
+ this.simulator = null;
16
+ this.isRunning = false;
17
+ this.lambdaService = dependencies.lambda || null;
18
+ }
19
+
20
+ async initialize() {
21
+ const logger = require('../../utils/logger');
22
+ logger.debug(`Inicializando API Gateway Service na porta ${this.port}...`);
23
+
24
+ this.simulator = new APIGatewaySimulator(this.config);
25
+ await this.simulator.initialize();
26
+
27
+ this.server = new APIGatewayServer(this.port, this.config);
28
+ this.server.simulator = this.simulator;
29
+ this.server.lambdaService = this.lambdaService;
30
+
31
+ await this.server.initialize();
32
+
33
+ logger.debug('API Gateway Service inicializado');
34
+ }
35
+
36
+ injectDependencies(server) {
37
+ const ct = server.getService('cloudtrail');
38
+ if (ct?.simulator) this.simulator.audit.setTrail(ct.simulator);
39
+ }
40
+
41
+ async start() {
42
+ if (this.isRunning) return;
43
+ await this.server.start();
44
+ this.isRunning = true;
45
+ }
46
+
47
+ async stop() {
48
+ if (!this.isRunning) return;
49
+ await this.server.stop();
50
+ this.isRunning = false;
51
+ }
52
+
53
+ async reset() {
54
+ await this.simulator.reset();
55
+ }
56
+
57
+ getStatus() {
58
+ return {
59
+ running: this.isRunning,
60
+ port: this.port,
61
+ endpoint: `http://localhost:${this.port}`,
62
+ apisCount: this.simulator?.getAPIsCount() || 0,
63
+ deploymentsCount: this.simulator?.getDeploymentsCount() || 0,
64
+ stagesCount: this.simulator?.getStagesCount() || 0,
65
+ resourcesCount: this.simulator?.getResourcesCount() || 0
66
+ };
67
+ }
68
+
69
+ getSimulator() {
70
+ return this.simulator;
71
+ }
72
+ }
73
+
69
74
  module.exports = APIGatewayService;