@gugananuvem/aws-local-simulator 1.0.0 → 1.0.2

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