Skip to content

Commit

Permalink
[3.0.0] Upgraded to programming model v4.
Browse files Browse the repository at this point in the history
  • Loading branch information
maaaNu committed Jul 2, 2024
1 parent 0a6d703 commit b81eec6
Show file tree
Hide file tree
Showing 35 changed files with 5,303 additions and 3,410 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# CHANGELOG

## 3.0.0 (27.06.2024)
~ Upgraded to Programming Model v4 (https://techcommunity.microsoft.com/t5/apps-on-azure-blog/azure-functions-node-js-v4-programming-model-is-generally/ba-p/3929217)

## 2.3.1 (26.02.2024)
~ Bump the version of jwt-decode

Expand Down
10 changes: 10 additions & 0 deletions example/.funcignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
*.js.map
*.ts
.git*
.vscode
__azurite_db*__.json
__blobstorage__
__queuestorage__
local.settings.json
test
tsconfig.json
2 changes: 1 addition & 1 deletion example/host.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@
},
"extensionBundle": {
"id": "Microsoft.Azure.Functions.ExtensionBundle",
"version": "[2.*, 3.0.0)"
"version": "[4.*, 5.0.0)"
}
}
132 changes: 100 additions & 32 deletions example/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 8 additions & 7 deletions example/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@
"version": "1.0.0",
"description": "Test project to demonstrate the azure-function-middleware",
"scripts": {
"test": "jest",
"build": "tsc",
"start:host": "func start --port 8080 --javascript",
"start": "npm-run-all --parallel start:host watch",
"watch": "tsc --w"
"watch": "tsc -w",
"clean": "rimraf dist",
"prestart": "npm run clean && npm run build",
"start": "func start"
},
"keywords": [
"azure",
Expand All @@ -25,8 +25,9 @@
"typescript": "^4.4.3"
},
"dependencies": {
"@azure/functions": "^3.0.0",
"@azure/functions": "4.4.0",
"@types/node": "^18.11.18",
"joi": "^17.9.1"
}
"joi": "^17.13.3"
},
"main": "dist/example/src/*.js"
}
1 change: 1 addition & 0 deletions example/request.http
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
POST http://localhost:8080/api/authentication
17 changes: 17 additions & 0 deletions example/src/invocationHook.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { PostInvocationContext, PreInvocationContext, app } from '@azure/functions';

app.hook.preInvocation((context: PreInvocationContext) => {
if (context.invocationContext.options.trigger.type === 'httpTrigger') {
context.invocationContext.log(
`preInvocation hook executed for http function ${context.invocationContext.functionName}`,
);
}
});

app.hook.postInvocation((context: PostInvocationContext) => {
if (context.invocationContext.options.trigger.type === 'httpTrigger') {
context.invocationContext.log(
`postInvocation hook executed for http function ${context.invocationContext.functionName}`,
);
}
});
16 changes: 16 additions & 0 deletions example/src/test-header-authentication-function.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { HttpRequest, InvocationContext, app } from '@azure/functions';

import { middleware } from '../../src';
import headerAuthentication from '../../src/headerAuthentication';

export const handler = async (request: HttpRequest, context: InvocationContext) => {
context.info('Function called');
return { status: 204 };
};

app.http('test-header-authentication-function', {
methods: ['POST'],
authLevel: 'anonymous',
route: 'authentication',
handler: middleware([headerAuthentication()], handler, []),
});
27 changes: 27 additions & 0 deletions example/src/test-jwt-authorization-function.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { HttpHandler, HttpRequestParams, app } from '@azure/functions';

import { middleware } from '../../src';
import authorization from '../../src/jwtAuthorization';

export const handler: HttpHandler = async (req, context) => {
context.log('Function called');
return { status: 204 };
};

app.http('test-jwt-authorization-function', {
methods: ['POST'],
authLevel: 'anonymous',
route: 'authorization/{id}',
handler: middleware<HttpHandler>(
[
authorization([
{
parameterExtractor: (parameters: HttpRequestParams) => parameters.id,
jwtExtractor: (jwt: { userId: string }) => jwt.userId,
},
]),
],
handler,
[],
),
});
29 changes: 29 additions & 0 deletions example/src/test-validation-function.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import { HttpHandler, app } from '@azure/functions';
import * as Joi from 'joi';
import { ObjectSchema } from 'joi';

import { PostExecutionFunction, middleware } from '../../src';
import { requestValidation as validation } from '../../src/validation';

const schema: ObjectSchema = Joi.object({
name: Joi.string().min(3).max(30).required(),
}).required();

export const functionHandler: HttpHandler = async (req, context) => {
context.info('Function called');
const body = (await req.json()) as { name: string };

return { status: 200, jsonBody: { text: `Hallo ${body.name}` } };
};

const postFunction: PostExecutionFunction = (_, context) => {
context.log('Called after function');
return;
};

app.http('test-validation-function', {
methods: ['POST'],
authLevel: 'anonymous',
route: 'validation',
handler: middleware<HttpHandler>([validation(schema, { printInput: true })], functionHandler, [postFunction]),
});
Loading

0 comments on commit b81eec6

Please sign in to comment.