@yopdev/dev-server 3.0.3-beta.7 → 3.0.4

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.
@@ -7,6 +7,10 @@ on:
7
7
  release:
8
8
  types: [created]
9
9
 
10
+ permissions:
11
+ id-token: write # Required for OIDC
12
+ contents: read
13
+
10
14
  jobs:
11
15
  build:
12
16
  timeout-minutes: 5
@@ -31,8 +35,8 @@ jobs:
31
35
  with:
32
36
  node-version: 20
33
37
  registry-url: https://registry.npmjs.org/
38
+ - name: Upgrade npm
39
+ run: npm install -g npm@latest
34
40
  - run: npm ci
35
41
  - run: npm run compile
36
42
  - run: npm publish
37
- env:
38
- NODE_AUTH_TOKEN: ${{secrets.npm_token}}
@@ -1,9 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.assertNotUndefined = void 0;
3
+ exports.assertNotUndefined = assertNotUndefined;
4
4
  function assertNotUndefined(value, message = 'value is undefined') {
5
5
  if (value === undefined)
6
6
  throw new Error(message);
7
7
  return value;
8
8
  }
9
- exports.assertNotUndefined = assertNotUndefined;
@@ -4,7 +4,7 @@ import { HttpSettings } from './http-server';
4
4
  import { Authorizer, Route } from './lambda-http-proxy';
5
5
  import { Callback, Service, Startable } from './services';
6
6
  import { LambdaPayloadVersion } from './mappers';
7
- export declare const newLambdaProxyFromCloudFormationTemplate: <Context, Event_1, HandlerResponse>(name: string, settings: HttpSettings, payloadVersion: LambdaPayloadVersion<Event_1, HandlerResponse>, config: CloudFormationLambdaProxyConfig<Context, Event_1, HandlerResponse>, callback: Callback<string>) => Startable<Service<string>>;
7
+ export declare const newLambdaProxyFromCloudFormationTemplate: <Context, Event, HandlerResponse>(name: string, settings: HttpSettings, payloadVersion: LambdaPayloadVersion<Event, HandlerResponse>, config: CloudFormationLambdaProxyConfig<Context, Event, HandlerResponse>, callback: Callback<string>) => Startable<Service<string>>;
8
8
  type CloudFormationLambdaProxyConfig<Context, Event, HandlerResponse> = {
9
9
  authorizer?: (config: DevServerConfig) => Authorizer | undefined;
10
10
  extraRoutes: Route<Context, Event, HandlerResponse>[];
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  import { IncomingMessage, ServerResponse } from "http";
3
2
  import { Lifecycle, Service, Callback } from "./services";
4
3
  export declare const newHttpServer: (name: string, config: {
@@ -1,12 +1,11 @@
1
- /// <reference types="node" />
2
1
  import { HttpSettings } from "./http-server";
3
2
  import { LambdaMapperFactory } from "./mappers";
4
3
  import { Service, Callback } from "./services";
5
4
  import { APIGatewayAuthorizerResult } from "aws-lambda";
6
- export declare const newLambdaHttpProxy: <Context, Event_1, HandlerResponse>(name: string, config: {
5
+ export declare const newLambdaHttpProxy: <Context, Event, HandlerResponse>(name: string, config: {
7
6
  settings: HttpSettings;
8
- routes: Route<Context, Event_1, HandlerResponse>[];
9
- mapper: LambdaMapperFactory<Event_1, HandlerResponse>;
7
+ routes: Route<Context, Event, HandlerResponse>[];
8
+ mapper: LambdaMapperFactory<Event, HandlerResponse>;
10
9
  authorizer?: Authorizer;
11
10
  context?: () => Context;
12
11
  }, callback?: Callback<string>) => Service<string>;
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  import { Message } from "@aws-sdk/client-sqs";
3
2
  import { APIGatewayAuthorizerResult, APIGatewayProxyEvent, APIGatewayProxyEventPathParameters, APIGatewayProxyEventV2, APIGatewayProxyResult, APIGatewayProxyStructuredResultV2, SQSRecord } from "aws-lambda";
4
3
  import { IncomingMessage } from "http";
@@ -66,7 +66,7 @@ class DefaultLambdaMapper {
66
66
  // V1: fallback to single header
67
67
  if ('headers' in response && response.headers?.['Set-Cookie']) {
68
68
  const cookieHeader = response.headers['Set-Cookie'];
69
- return Array.isArray(cookieHeader) ? cookieHeader.map(c => c.toString()) : [cookieHeader];
69
+ return Array.isArray(cookieHeader) ? cookieHeader.map(c => c.toString()) : [cookieHeader.toString()];
70
70
  }
71
71
  return [];
72
72
  };
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { ServerResponse } from 'http';
4
2
  export declare function internalServerError(res: ServerResponse, body: any): void;
5
3
  export declare function writeResponse(res: ServerResponse, statusCode: number, body: string | Buffer, contentType?: string, location?: string, cookies?: string[]): void;
@@ -1,13 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.writeResponse = exports.internalServerError = void 0;
3
+ exports.internalServerError = internalServerError;
4
+ exports.writeResponse = writeResponse;
4
5
  const logging_1 = require("@yopdev/logging");
5
6
  const LOG = logging_1.LoggerFactory.create('RESPONSES');
6
7
  function internalServerError(res, body) {
7
8
  LOG.error(body, 'internal server error handled');
8
9
  return writeResponse(res, 500, 'internal server error. check system logs');
9
10
  }
10
- exports.internalServerError = internalServerError;
11
11
  function writeResponse(res, statusCode, body, contentType, location, cookies) {
12
12
  res.setHeader('Access-Control-Allow-Origin', '*');
13
13
  res.setHeader('Access-Control-Allow-Methods', '*');
@@ -22,4 +22,3 @@ function writeResponse(res, statusCode, body, contentType, location, cookies) {
22
22
  res.statusCode = statusCode;
23
23
  res.end(body);
24
24
  }
25
- exports.writeResponse = writeResponse;
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
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
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  Object.defineProperty(exports, "__esModule", { value: true });
26
36
  exports.newTunnel = exports.terminate = void 0;
27
37
  const services_1 = require("./services");
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@yopdev/dev-server",
3
- "version": "3.0.3-beta.7",
3
+ "version": "3.0.4",
4
4
  "scripts": {
5
5
  "compile": "tsc",
6
6
  "pretest": "npm run compile",
@@ -12,16 +12,16 @@
12
12
  "devDependencies": {
13
13
  "@types/aws-lambda": "8.10.114",
14
14
  "@types/js-yaml": "^4.0.9",
15
- "@types/node": "^20.9.0",
16
- "axios": "^1.6.2",
15
+ "@types/node": "^25.3.3",
16
+ "axios": "^1.13.5",
17
17
  "ts-jest": "^29.1.1",
18
- "typescript": "^5.2.2"
18
+ "typescript": "^5.9.3"
19
19
  },
20
20
  "dependencies": {
21
- "@aws-sdk/client-dynamodb": "^3.451.0",
22
- "@aws-sdk/client-s3": "^3.451.0",
23
- "@aws-sdk/client-sns": "^3.451.0",
24
- "@aws-sdk/client-sqs": "^3.451.0",
21
+ "@aws-sdk/client-dynamodb": "^3.996.0",
22
+ "@aws-sdk/client-s3": "^3.996.0",
23
+ "@aws-sdk/client-sns": "^3.996.0",
24
+ "@aws-sdk/client-sqs": "^3.996.0",
25
25
  "@ngrok/ngrok": "^0.9.1",
26
26
  "@yopdev/logging": "^0.0.6",
27
27
  "js-yaml": "^4.1.1",
package/src/mappers.ts CHANGED
@@ -114,7 +114,7 @@ class DefaultLambdaMapper implements LambdaMapper<APIGatewayProxyEvent & APIGate
114
114
  // V1: fallback to single header
115
115
  if ('headers' in response && response.headers?.['Set-Cookie']) {
116
116
  const cookieHeader = response.headers['Set-Cookie'];
117
- return Array.isArray(cookieHeader) ? cookieHeader.map(c => c.toString()) : [cookieHeader];
117
+ return Array.isArray(cookieHeader) ? cookieHeader.map(c => c.toString()) : [cookieHeader.toString()];
118
118
  }
119
119
 
120
120
  return [];