@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
@@ -1,71 +1,71 @@
1
- /**
2
- * DynamoDB Service - Ponto de entrada
3
- * Exporta o serviço principal e seus componentes
4
- */
5
-
6
- const DynamoDBServer = require('./server');
7
- const DynamoDBSimulator = require('./simulator');
8
- const LocalStore = require('../../utils/local-store');
9
-
10
- class DynamoDBService {
11
- constructor(config) {
12
- this.config = config;
13
- this.name = 'dynamodb';
14
- this.port = config.ports.dynamodb;
15
- this.server = null;
16
- this.simulator = null;
17
- this.isRunning = false;
18
- }
19
-
20
- async initialize() {
21
- const logger = require('../../utils/logger');
22
- logger.debug(`Inicializando DynamoDB Service na porta ${this.port}...`);
23
-
24
- // Cria o simulador
25
- this.simulator = new DynamoDBSimulator(this.config);
26
-
27
- // Cria o servidor HTTP
28
- this.server = new DynamoDBServer(this.port, this.config);
29
- this.server.simulator = this.simulator;
30
-
31
- await this.server.initialize();
32
-
33
- logger.debug('DynamoDB 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
- tablesCount: this.simulator?.getTablesCount() || 0,
58
- itemsCount: this.simulator?.getTotalItems() || 0
59
- };
60
- }
61
-
62
- getSimulator() {
63
- return this.simulator;
64
- }
65
-
66
- getServer() {
67
- return this.server;
68
- }
69
- }
70
-
1
+ /**
2
+ * DynamoDB Service - Ponto de entrada
3
+ * Exporta o serviço principal e seus componentes
4
+ */
5
+
6
+ const DynamoDBServer = require('./server');
7
+ const DynamoDBSimulator = require('./simulator');
8
+ const LocalStore = require('../../utils/local-store');
9
+
10
+ class DynamoDBService {
11
+ constructor(config) {
12
+ this.config = config;
13
+ this.name = 'dynamodb';
14
+ this.port = config.ports.dynamodb;
15
+ this.server = null;
16
+ this.simulator = null;
17
+ this.isRunning = false;
18
+ }
19
+
20
+ async initialize() {
21
+ const logger = require('../../utils/logger');
22
+ logger.debug(`Inicializando DynamoDB Service na porta ${this.port}...`);
23
+
24
+ // Cria o simulador
25
+ this.simulator = new DynamoDBSimulator(this.config);
26
+
27
+ // Cria o servidor HTTP
28
+ this.server = new DynamoDBServer(this.port, this.config);
29
+ this.server.simulator = this.simulator;
30
+
31
+ await this.server.initialize();
32
+
33
+ logger.debug('DynamoDB 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
+ tablesCount: this.simulator?.getTablesCount() || 0,
58
+ itemsCount: this.simulator?.getTotalItems() || 0
59
+ };
60
+ }
61
+
62
+ getSimulator() {
63
+ return this.simulator;
64
+ }
65
+
66
+ getServer() {
67
+ return this.server;
68
+ }
69
+ }
70
+
71
71
  module.exports = DynamoDBService;
@@ -1,122 +1,122 @@
1
- /**
2
- * DynamoDB Server - Servidor HTTP para DynamoDB
3
- */
4
-
5
- const express = require('express');
6
- const DynamoDBSimulator = require('./simulator');
7
- const logger = require('../../utils/logger');
8
-
9
- class DynamoDBServer {
10
- constructor(port, config) {
11
- this.port = port;
12
- this.config = config;
13
- this.app = express();
14
- this.simulator = null;
15
- this.server = null;
16
- this.setupMiddlewares();
17
- }
18
-
19
- setupMiddlewares() {
20
- this.app.use(express.json({
21
- type: 'application/x-amz-json-1.0'
22
- }));
23
-
24
- // Logging de requisições
25
- if (logger.currentLogLevel === 'verboso') {
26
- this.app.use((req, res, next) => {
27
- const start = Date.now();
28
- res.on('finish', () => {
29
- const duration = Date.now() - start;
30
- logger.verboso(`DynamoDB: ${req.headers['x-amz-target'] || req.method} - ${duration}ms`);
31
- });
32
- next();
33
- });
34
- }
35
- }
36
-
37
- async initialize() {
38
- this.simulator = new DynamoDBSimulator(this.config);
39
- await this.simulator.initialize();
40
- this.setupRoutes();
41
- }
42
-
43
- setupRoutes() {
44
- // Endpoint principal
45
- this.app.post('/', async (req, res) => {
46
- const target = req.headers['x-amz-target'];
47
-
48
- if (!target) {
49
- return res.status(400).json({ message: 'Missing X-Amz-Target header' });
50
- }
51
-
52
- try {
53
- const result = await this.simulator.handleRequest(target, req.body);
54
- res.json(result);
55
- } catch (error) {
56
- logger.error('DynamoDB Error:', error);
57
- res.status(400).json({
58
- __type: error.code || 'InternalServerError',
59
- message: error.message
60
- });
61
- }
62
- });
63
-
64
- // Admin endpoints
65
- this.setupAdminRoutes();
66
- }
67
-
68
- setupAdminRoutes() {
69
- this.app.get('/__admin/tables', (req, res) => {
70
- res.json(this.simulator.listTables());
71
- });
72
-
73
- this.app.get('/__admin/tables/:tableName', (req, res) => {
74
- const table = this.simulator.describeTable(req.params.tableName);
75
- res.json(table);
76
- });
77
-
78
- this.app.get('/__admin/tables/:tableName/items', (req, res) => {
79
- const items = this.simulator.scan({ TableName: req.params.tableName });
80
- res.json(items);
81
- });
82
-
83
- this.app.delete('/__admin/tables/:tableName', (req, res) => {
84
- this.simulator.truncateTable(req.params.tableName);
85
- res.json({ message: `Table ${req.params.tableName} truncated` });
86
- });
87
-
88
- this.app.get('/__admin/stats', (req, res) => {
89
- res.json(this.simulator.getStats());
90
- });
91
- }
92
-
93
- start() {
94
- return new Promise((resolve) => {
95
- this.server = this.app.listen(this.port, () => {
96
- logger.info(`🗄️ DynamoDB rodando em http://localhost:${this.port}`);
97
- resolve();
98
- });
99
- });
100
- }
101
-
102
- stop() {
103
- return new Promise((resolve) => {
104
- if (this.server) {
105
- this.server.close(() => resolve());
106
- } else {
107
- resolve();
108
- }
109
- });
110
- }
111
-
112
- getStatus() {
113
- return {
114
- running: !!this.server,
115
- port: this.port,
116
- endpoint: `http://localhost:${this.port}`,
117
- tablesCount: this.simulator?.getTablesCount() || 0
118
- };
119
- }
120
- }
121
-
1
+ /**
2
+ * DynamoDB Server - Servidor HTTP para DynamoDB
3
+ */
4
+
5
+ const express = require('express');
6
+ const DynamoDBSimulator = require('./simulator');
7
+ const logger = require('../../utils/logger');
8
+
9
+ class DynamoDBServer {
10
+ constructor(port, config) {
11
+ this.port = port;
12
+ this.config = config;
13
+ this.app = express();
14
+ this.simulator = null;
15
+ this.server = null;
16
+ this.setupMiddlewares();
17
+ }
18
+
19
+ setupMiddlewares() {
20
+ this.app.use(express.json({
21
+ type: 'application/x-amz-json-1.0'
22
+ }));
23
+
24
+ // Logging de requisições
25
+ if (logger.currentLogLevel === 'verboso') {
26
+ this.app.use((req, res, next) => {
27
+ const start = Date.now();
28
+ res.on('finish', () => {
29
+ const duration = Date.now() - start;
30
+ logger.verboso(`DynamoDB: ${req.headers['x-amz-target'] || req.method} - ${duration}ms`);
31
+ });
32
+ next();
33
+ });
34
+ }
35
+ }
36
+
37
+ async initialize() {
38
+ this.simulator = new DynamoDBSimulator(this.config);
39
+ await this.simulator.initialize();
40
+ this.setupRoutes();
41
+ }
42
+
43
+ setupRoutes() {
44
+ // Endpoint principal
45
+ this.app.post('/', async (req, res) => {
46
+ const target = req.headers['x-amz-target'];
47
+
48
+ if (!target) {
49
+ return res.status(400).json({ message: 'Missing X-Amz-Target header' });
50
+ }
51
+
52
+ try {
53
+ const result = await this.simulator.handleRequest(target, req.body);
54
+ res.json(result);
55
+ } catch (error) {
56
+ logger.error('DynamoDB Error:', error);
57
+ res.status(400).json({
58
+ __type: error.code || 'InternalServerError',
59
+ message: error.message
60
+ });
61
+ }
62
+ });
63
+
64
+ // Admin endpoints
65
+ this.setupAdminRoutes();
66
+ }
67
+
68
+ setupAdminRoutes() {
69
+ this.app.get('/__admin/tables', (req, res) => {
70
+ res.json(this.simulator.listTables());
71
+ });
72
+
73
+ this.app.get('/__admin/tables/:tableName', (req, res) => {
74
+ const table = this.simulator.describeTable(req.params.tableName);
75
+ res.json(table);
76
+ });
77
+
78
+ this.app.get('/__admin/tables/:tableName/items', (req, res) => {
79
+ const items = this.simulator.scan({ TableName: req.params.tableName });
80
+ res.json(items);
81
+ });
82
+
83
+ this.app.delete('/__admin/tables/:tableName', (req, res) => {
84
+ this.simulator.truncateTable(req.params.tableName);
85
+ res.json({ message: `Table ${req.params.tableName} truncated` });
86
+ });
87
+
88
+ this.app.get('/__admin/stats', (req, res) => {
89
+ res.json(this.simulator.getStats());
90
+ });
91
+ }
92
+
93
+ start() {
94
+ return new Promise((resolve) => {
95
+ this.server = this.app.listen(this.port, () => {
96
+ logger.info(`🗄️ DynamoDB rodando em http://localhost:${this.port}`);
97
+ resolve();
98
+ });
99
+ });
100
+ }
101
+
102
+ stop() {
103
+ return new Promise((resolve) => {
104
+ if (this.server) {
105
+ this.server.close(() => resolve());
106
+ } else {
107
+ resolve();
108
+ }
109
+ });
110
+ }
111
+
112
+ getStatus() {
113
+ return {
114
+ running: !!this.server,
115
+ port: this.port,
116
+ endpoint: `http://localhost:${this.port}`,
117
+ tablesCount: this.simulator?.getTablesCount() || 0
118
+ };
119
+ }
120
+ }
121
+
122
122
  module.exports = DynamoDBServer;