@gugananuvem/aws-local-simulator 1.0.10 → 1.0.12

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