@yopdev/dev-server 3.0.0 → 3.0.2-RC

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 (57) hide show
  1. package/package.json +1 -1
  2. package/dist/src/assert.d.ts +0 -1
  3. package/dist/src/assert.js +0 -9
  4. package/dist/src/cloudformation-dynamodb-table.d.ts +0 -13
  5. package/dist/src/cloudformation-dynamodb-table.js +0 -45
  6. package/dist/src/cloudformation-event-proxy.d.ts +0 -13
  7. package/dist/src/cloudformation-event-proxy.js +0 -25
  8. package/dist/src/cloudformation-lambda-http-proxy.d.ts +0 -14
  9. package/dist/src/cloudformation-lambda-http-proxy.js +0 -62
  10. package/dist/src/cloudformation.d.ts +0 -28
  11. package/dist/src/cloudformation.js +0 -50
  12. package/dist/src/config.d.ts +0 -31
  13. package/dist/src/config.js +0 -2
  14. package/dist/src/container.d.ts +0 -18
  15. package/dist/src/container.js +0 -33
  16. package/dist/src/deferred.d.ts +0 -4
  17. package/dist/src/deferred.js +0 -45
  18. package/dist/src/dev-server.d.ts +0 -19
  19. package/dist/src/dev-server.js +0 -63
  20. package/dist/src/dynamodb.d.ts +0 -16
  21. package/dist/src/dynamodb.js +0 -48
  22. package/dist/src/event-proxy.d.ts +0 -13
  23. package/dist/src/event-proxy.js +0 -68
  24. package/dist/src/factories.d.ts +0 -3
  25. package/dist/src/factories.js +0 -16
  26. package/dist/src/http-server.d.ts +0 -25
  27. package/dist/src/http-server.js +0 -37
  28. package/dist/src/index.d.ts +0 -24
  29. package/dist/src/index.js +0 -46
  30. package/dist/src/internal-queue.d.ts +0 -11
  31. package/dist/src/internal-queue.js +0 -53
  32. package/dist/src/lambda-http-proxy.d.ts +0 -27
  33. package/dist/src/lambda-http-proxy.js +0 -49
  34. package/dist/src/localstack.d.ts +0 -11
  35. package/dist/src/localstack.js +0 -62
  36. package/dist/src/mappers.d.ts +0 -25
  37. package/dist/src/mappers.js +0 -156
  38. package/dist/src/pre-traffic-hooks.d.ts +0 -2
  39. package/dist/src/pre-traffic-hooks.js +0 -19
  40. package/dist/src/responses.d.ts +0 -5
  41. package/dist/src/responses.js +0 -22
  42. package/dist/src/s3.d.ts +0 -7
  43. package/dist/src/s3.js +0 -20
  44. package/dist/src/scheduled-tasks.d.ts +0 -6
  45. package/dist/src/scheduled-tasks.js +0 -20
  46. package/dist/src/services.d.ts +0 -22
  47. package/dist/src/services.js +0 -26
  48. package/dist/src/sns-http-proxy.d.ts +0 -28
  49. package/dist/src/sns-http-proxy.js +0 -66
  50. package/dist/src/sns.d.ts +0 -15
  51. package/dist/src/sns.js +0 -35
  52. package/dist/src/sqs.d.ts +0 -13
  53. package/dist/src/sqs.js +0 -33
  54. package/dist/src/stoppable.d.ts +0 -2
  55. package/dist/src/stoppable.js +0 -15
  56. package/dist/src/tunnel.d.ts +0 -10
  57. package/dist/src/tunnel.js +0 -52
@@ -1,5 +0,0 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
- import { ServerResponse } from 'http';
4
- export declare function internalServerError(res: ServerResponse, body: any): void;
5
- export declare function writeResponse(res: ServerResponse, statusCode: number, body: string | Buffer, contentType?: string, location?: string): void;
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.writeResponse = exports.internalServerError = void 0;
4
- const logging_1 = require("@yopdev/logging");
5
- const LOG = logging_1.LoggerFactory.create('RESPONSES');
6
- function internalServerError(res, body) {
7
- LOG.error(body, 'internal server error handled');
8
- return writeResponse(res, 500, 'internal server error. check system logs');
9
- }
10
- exports.internalServerError = internalServerError;
11
- function writeResponse(res, statusCode, body, contentType, location) {
12
- res.setHeader('Access-Control-Allow-Origin', '*');
13
- res.setHeader('Access-Control-Allow-Methods', '*');
14
- res.setHeader('Access-Control-Allow-Headers', '*');
15
- if (contentType)
16
- res.setHeader('Content-Type', contentType);
17
- if (location)
18
- res.setHeader('Location', location);
19
- res.statusCode = statusCode;
20
- res.end(body);
21
- }
22
- exports.writeResponse = writeResponse;
package/dist/src/s3.d.ts DELETED
@@ -1,7 +0,0 @@
1
- import { CORSConfiguration, S3Client } from '@aws-sdk/client-s3';
2
- import { AwsConfig } from './config';
3
- export declare class S3 {
4
- readonly client: S3Client;
5
- constructor(aws: AwsConfig);
6
- createBucket: (name: string, cors?: CORSConfiguration) => Promise<import("@aws-sdk/client-s3").PutBucketCorsCommandOutput>;
7
- }
package/dist/src/s3.js DELETED
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.S3 = void 0;
4
- const client_s3_1 = require("@aws-sdk/client-s3");
5
- const logging_1 = require("@yopdev/logging");
6
- const LOGGER = logging_1.LoggerFactory.create('S3');
7
- class S3 {
8
- constructor(aws) {
9
- this.createBucket = async (name, cors) => this.client.send(new client_s3_1.CreateBucketCommand({
10
- Bucket: name,
11
- }))
12
- .then(() => cors && this.client.send(new client_s3_1.PutBucketCorsCommand({
13
- Bucket: name,
14
- CORSConfiguration: cors
15
- })))
16
- .tap(() => LOGGER.debug('bucket %s created', name));
17
- this.client = new client_s3_1.S3Client({ forcePathStyle: true, ...aws });
18
- }
19
- }
20
- exports.S3 = S3;
@@ -1,6 +0,0 @@
1
- import { Service } from './services';
2
- export declare const newScheduledTasks: (name: string, schedules: Rate[]) => Service<any>;
3
- export type Rate = {
4
- frequency: number;
5
- task: () => Promise<unknown>;
6
- };
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.newScheduledTasks = void 0;
4
- const logging_1 = require("@yopdev/logging");
5
- const timers_1 = require("timers");
6
- const services_1 = require("./services");
7
- const newScheduledTasks = (name, schedules) => new services_1.Service(new ScheduledTasks(name, schedules));
8
- exports.newScheduledTasks = newScheduledTasks;
9
- class ScheduledTasks {
10
- constructor(name, schedules) {
11
- this.name = name;
12
- this.schedules = schedules;
13
- this.intervals = [];
14
- this.start = async () => Promise.resolve(this.schedules.forEach((schedule) => this.intervals.push(setInterval(schedule.task, schedule.frequency * 1000))))
15
- .then(() => undefined);
16
- this.stop = async () => Promise.resolve(this.intervals.forEach((interval) => (0, timers_1.clearInterval)(interval)));
17
- this.LOGGER = logging_1.LoggerFactory.create(`SCHEDULER[${name}]`);
18
- this.LOGGER.info('registered %i scheduled tasks', schedules.length);
19
- }
20
- }
@@ -1,22 +0,0 @@
1
- import { DevServerConfig } from "./config";
2
- export interface Lifecycle<I> extends Startable<I>, Stoppable {
3
- name: string;
4
- }
5
- export interface Startable<T> {
6
- start(config: DevServerConfig): Promise<T>;
7
- }
8
- export interface Stoppable {
9
- stop(): Promise<void>;
10
- }
11
- export type Callback<I> = (instance: I) => Promise<void>;
12
- export declare class Service<I> implements Lifecycle<I> {
13
- private readonly callback?;
14
- private readonly DEFAULT_CALLBACK;
15
- readonly name: string;
16
- readonly start: (config: DevServerConfig) => Promise<I>;
17
- readonly stop: () => Promise<void>;
18
- private doStop;
19
- private readonly LOGGER;
20
- constructor(service: Lifecycle<I>, callback?: Callback<I>);
21
- private callbackOrDefault;
22
- }
@@ -1,26 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Service = void 0;
4
- const logging_1 = require("@yopdev/logging");
5
- class Service {
6
- constructor(service, callback) {
7
- this.callback = callback;
8
- this.DEFAULT_CALLBACK = () => Promise.resolve(this.LOGGER.debug('no callback'));
9
- this.callbackOrDefault = async (instance) => (this.callback ?? this.DEFAULT_CALLBACK)(instance);
10
- this.name = service.name;
11
- this.LOGGER = logging_1.LoggerFactory.create(`SERVICE[${this.name}]`);
12
- const stop = async () => service.stop();
13
- this.start = (config) => service.start(config)
14
- .catch((error) => stop()
15
- .then(() => this.doStop = () => Promise.resolve(this.LOGGER.error(error, 'failed')))
16
- .then(() => Promise.reject(error)))
17
- .then((started) => this
18
- .callbackOrDefault(started)
19
- .then(() => this.LOGGER.info('started'))
20
- .then(() => started));
21
- this.doStop = () => stop()
22
- .then(() => this.LOGGER.info('stopped'));
23
- this.stop = () => this.doStop();
24
- }
25
- }
26
- exports.Service = Service;
@@ -1,28 +0,0 @@
1
- import { HttpSettings } from "./http-server";
2
- import { IncomingMessage, ServerResponse } from "http";
3
- import { Lifecycle, Service, Callback } from "./services";
4
- import { DevServerConfig } from "./config";
5
- export declare const newSnsHttpProxy: (name: string, config: {
6
- settings: HttpSettings;
7
- method: string;
8
- subject?: string;
9
- topic?: string;
10
- }, callback?: Callback<string>) => Service<string>;
11
- export declare class SnsHttpProxy implements Lifecycle<string> {
12
- readonly name: string;
13
- private readonly settings;
14
- private readonly method;
15
- private readonly subject?;
16
- private readonly topic?;
17
- private LOGGER;
18
- private server;
19
- private config;
20
- constructor(name: string, settings: HttpSettings, method: string, subject?: string, topic?: string);
21
- start: (config: DevServerConfig) => Promise<string>;
22
- stop: () => Promise<void>;
23
- handler: (method: string, subject?: string) => (request: IncomingMessage, body: string, response: ServerResponse) => Promise<void>;
24
- extractMessage: (method: string, request: IncomingMessage, body: string) => string;
25
- private onlyWhenStarted;
26
- private extractQueryString;
27
- private extractMessageAttributes;
28
- }
@@ -1,66 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SnsHttpProxy = exports.newSnsHttpProxy = void 0;
4
- const logging_1 = require("@yopdev/logging");
5
- const http_server_1 = require("./http-server");
6
- const responses_1 = require("./responses");
7
- const services_1 = require("./services");
8
- const assert_1 = require("./assert");
9
- const newSnsHttpProxy = (name, config, callback) => new services_1.Service(new SnsHttpProxy(name, config.settings, config.method, config.subject, config.topic), callback);
10
- exports.newSnsHttpProxy = newSnsHttpProxy;
11
- class SnsHttpProxy {
12
- constructor(name, settings, method, subject, topic) {
13
- this.name = name;
14
- this.settings = settings;
15
- this.method = method;
16
- this.subject = subject;
17
- this.topic = topic;
18
- this.start = (config) => Promise.resolve(this.server)
19
- .then(server => server.start())
20
- .tap(() => {
21
- this.config = {
22
- topic: this.topic ?? config.eventsProxy.topic.arn,
23
- sns: config.sns
24
- };
25
- })
26
- .then((endpoint) => endpoint);
27
- this.stop = () => this.onlyWhenStarted(this.server).stop()
28
- .then(() => this.LOGGER.debug('stopped'));
29
- this.handler = (method, subject) => (request, body, response) => Promise.resolve(((0, assert_1.assertNotUndefined)(this.config)))
30
- .then((config) => config.sns
31
- .publish({ arn: config.topic }, this.extractMessage(method, request, body), subject, this.extractMessageAttributes(request))
32
- .then(() => (0, responses_1.writeResponse)(response, 200, ''))
33
- .catch((e) => {
34
- this.LOGGER.error(e, 'request failed to execute');
35
- (0, responses_1.internalServerError)(response, e.body);
36
- }));
37
- this.extractMessage = (method, request, body) => {
38
- switch (method) {
39
- case 'GET':
40
- return this.extractQueryString(request) || '';
41
- case 'POST':
42
- return body;
43
- default:
44
- throw new Error();
45
- }
46
- };
47
- this.onlyWhenStarted = (server) => (0, assert_1.assertNotUndefined)(server, 'not started');
48
- this.extractQueryString = (request) => request.url?.substring(request.url?.indexOf('?') + 1);
49
- this.extractMessageAttributes = (request) => {
50
- const initialValue = {};
51
- return Object.keys(request.headers).reduce((obj, item) => {
52
- return {
53
- ...obj,
54
- [item]: {
55
- DataType: 'String',
56
- StringValue: request.headers[item],
57
- },
58
- };
59
- }, initialValue);
60
- };
61
- this.server = new http_server_1.HttpServer(this.name, this.settings, this.handler(this.method, this.subject));
62
- this.LOGGER = logging_1.LoggerFactory.create(`HTTP->SNS[${name}]`);
63
- this.LOGGER.info('forwarding %s %s events to %s', subject ? `events with ${subject} subject` : 'all', method, topic ?? 'the event bus');
64
- }
65
- }
66
- exports.SnsHttpProxy = SnsHttpProxy;
package/dist/src/sns.d.ts DELETED
@@ -1,15 +0,0 @@
1
- import { MessageAttributeValue, SNSClient } from "@aws-sdk/client-sns";
2
- import { AwsConfig } from "./config";
3
- export declare class Sns {
4
- readonly client: SNSClient;
5
- constructor(aws: AwsConfig);
6
- createTopic: (topic: string) => Promise<string>;
7
- createSubscription: (topic: {
8
- arn: string;
9
- }, queue: {
10
- arn: string;
11
- }) => Promise<void>;
12
- publish: (topic: {
13
- arn: string;
14
- }, body: string, subject?: string, attributes?: Record<string, MessageAttributeValue>) => Promise<void>;
15
- }
package/dist/src/sns.js DELETED
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Sns = void 0;
4
- const client_sns_1 = require("@aws-sdk/client-sns");
5
- const assert_1 = require("./assert");
6
- const logging_1 = require("@yopdev/logging");
7
- const LOGGER = logging_1.LoggerFactory.create('SNS');
8
- class Sns {
9
- constructor(aws) {
10
- this.createTopic = async (topic) => this.client
11
- .send(new client_sns_1.CreateTopicCommand({
12
- Name: topic,
13
- }))
14
- .then((o) => (0, assert_1.assertNotUndefined)(o.TopicArn, 'TopicArn is not present'))
15
- .tap((arn) => LOGGER.debug('topic %o created', arn));
16
- this.createSubscription = async (topic, queue) => this.client
17
- .send(new client_sns_1.SubscribeCommand({
18
- TopicArn: topic.arn,
19
- Protocol: 'sqs',
20
- Endpoint: queue.arn,
21
- }))
22
- .then(() => LOGGER.debug('subscription %s->%s created', topic.arn, queue.arn));
23
- this.publish = async (topic, body, subject, attributes) => this.client
24
- .send(new client_sns_1.PublishCommand({
25
- TopicArn: topic.arn,
26
- Message: body,
27
- MessageAttributes: attributes,
28
- Subject: subject,
29
- }))
30
- .then(() => LOGGER.trace('published %s[%s]', topic.arn, subject))
31
- .then();
32
- this.client = new client_sns_1.SNSClient(aws);
33
- }
34
- }
35
- exports.Sns = Sns;
package/dist/src/sqs.d.ts DELETED
@@ -1,13 +0,0 @@
1
- import { SQSClient } from "@aws-sdk/client-sqs";
2
- import { AwsConfig } from "./config";
3
- export declare class Sqs {
4
- readonly client: SQSClient;
5
- constructor(config: AwsConfig);
6
- createStandardQueue: (name: string) => Promise<Queue>;
7
- createFifoQueue: (name: string) => Promise<Queue>;
8
- private createNamedQueue;
9
- }
10
- export type Queue = {
11
- arn: string;
12
- url: string;
13
- };
package/dist/src/sqs.js DELETED
@@ -1,33 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Sqs = void 0;
4
- const client_sqs_1 = require("@aws-sdk/client-sqs");
5
- const assert_1 = require("./assert");
6
- const logging_1 = require("@yopdev/logging");
7
- const QUEUE_NAME_ATTRIBUTE_NAME = 'QueueArn';
8
- const LOGGER = logging_1.LoggerFactory.create('SQS');
9
- class Sqs {
10
- constructor(config) {
11
- this.createStandardQueue = async (name) => this.createNamedQueue(name, false);
12
- this.createFifoQueue = async (name) => this.createNamedQueue(name, true);
13
- this.createNamedQueue = async (name, fifo) => this.client
14
- .send(new client_sqs_1.CreateQueueCommand({
15
- QueueName: fifo ? `${name}.fifo` : name,
16
- Attributes: {
17
- FifoQueue: fifo ? 'true' : undefined,
18
- }
19
- }))
20
- .then((create) => this.client
21
- .send(new client_sqs_1.GetQueueAttributesCommand({
22
- QueueUrl: create.QueueUrl,
23
- AttributeNames: [QUEUE_NAME_ATTRIBUTE_NAME],
24
- }))
25
- .then((attributes) => ({
26
- url: (0, assert_1.assertNotUndefined)(create.QueueUrl),
27
- arn: (0, assert_1.assertNotUndefined)(attributes.Attributes)[QUEUE_NAME_ATTRIBUTE_NAME],
28
- })))
29
- .tap((queue) => LOGGER.debug('created %s', queue.arn));
30
- this.client = new client_sqs_1.SQSClient(config);
31
- }
32
- }
33
- exports.Sqs = Sqs;
@@ -1,2 +0,0 @@
1
- import { Consumer } from "sqs-consumer";
2
- export declare const stopConsumer: (queueWaitTimeSecs: number, target?: Consumer) => Promise<void>;
@@ -1,15 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.stopConsumer = void 0;
4
- const stopConsumer = async (queueWaitTimeSecs, target) => {
5
- if (target) {
6
- target.stop();
7
- return new Promise((resolve) => {
8
- setTimeout(resolve, queueWaitTimeSecs * 1000 + 1);
9
- });
10
- }
11
- else {
12
- return Promise.resolve();
13
- }
14
- };
15
- exports.stopConsumer = stopConsumer;
@@ -1,10 +0,0 @@
1
- import { Service } from './services';
2
- export declare const terminate: () => Promise<void>;
3
- export declare const newTunnel: (config: {
4
- name: string;
5
- port: number;
6
- fixed?: {
7
- name: string;
8
- token: string;
9
- };
10
- }) => Service<string>;
@@ -1,52 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.newTunnel = exports.terminate = void 0;
27
- const services_1 = require("./services");
28
- const logging_1 = require("@yopdev/logging");
29
- const ngrok = __importStar(require("@ngrok/ngrok"));
30
- const assert_1 = require("./assert");
31
- const terminate = async () => ngrok.kill();
32
- exports.terminate = terminate;
33
- const newTunnel = (config) => new services_1.Service(new Tunnel(config.name, config.port, config.fixed));
34
- exports.newTunnel = newTunnel;
35
- class Tunnel {
36
- constructor(name, port, domain) {
37
- this.name = name;
38
- this.port = port;
39
- this.domain = domain;
40
- this.start = async () => ngrok
41
- .forward({
42
- proto: 'http',
43
- domain: this.domain?.name,
44
- addr: this.port,
45
- authtoken: this.domain?.token,
46
- })
47
- .then((listener) => (0, assert_1.assertNotUndefined)(listener.url()))
48
- .tap((url) => this.logger.debug(url));
49
- this.stop = async () => ngrok.disconnect();
50
- this.logger = logging_1.LoggerFactory.create(`TUNNEL[${name}]`);
51
- }
52
- }