You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
The new Node.js programming model is now Generally Available! 🎉 This changelog is meant as a detailed list of changes in the new version. See the official upgrade guide for a less detailed, more user-friendly list of the changes.
Added
Support registering functions directly in your code instead of in function.json files #569 and #480
Allow classes like InvocationContext and HttpRequest to be constructed in test environments outside the Azure Functions runtime
Changed
Update minimum version of Node.js to 18.x
Update minimum version of TypeScript to 4.x
Switch the order of arguments. For example, (request, context) is now (context, request)#34
Remove context.done(). We assume your function (async or sync) is done as soon as it returns
Remove context.executionContext. You can find functionName and retryContext on the root context object instead
Remove context.bindingDefinitions in favor of context.options
Remove context.log sub-methods (context.log.error/context.log.warn/etc.) in favor of methods on the root context object (context.error/context.warn/etc.). Also Remove the verbose option in favor of trace and debug to match Node.js's console methods
Remove context.req, context,res, and context.bindings. The primary input is always an argument to your function, the primary output is always the return value of your function, and everything else can be accessed on context.extraInputs or context.extraOutputs
Clean up context.bindingMetadata
Rename to context.triggerMetadata
Remove legacy sys property
Remove logic that was recursively attempting to convert objects from rpc values, causing #607
Make camel-case logic consistent so that it applies to the whole object - specifically including arrays which were previously excluded
Remove http classes that were unique to Azure Functions in favor of new classes representing a subset of the fetch standard based on the undici npm package.
Rename Request to HttpRequest
Change query from type HttpRequestQuery to Node.js core type URLSearchParams
Remove HttpResponseSimple/HttpResponseFull/HttpResponse types in favor of HttpResponse class and HttpResponseInit interface
Remove statusCode in favor of status
Remove end, send, sendStatus, and json. These were callback methods based on context.done() which is no longer supported
Remove header-related methods (setHeader, header, set, getHeader, get, removeHeader, type) from base response object. You must use response.headers for any header-related methods
Change headers from type HttpRequestHeaders/HttpResponseHeaders to fetch standard type Headers
Remove body properties body, rawBody, bufferBody, and parseFormBody() in favor of fetch standard methods arrayBuffer(), blob(), formData(), json(), and text()
Handle all falsy values appropriately. Treat it as data to be passed along instead of occasionally converting it to null#388
Remove setup() method. v4 of the programming model is automatically setup when you register any function from the app object
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
If you want to rebase/retry this PR, check this box
This PR has been generated by Mend Renovate. View repository job log here.
Merging this PR will not cause a version bump for any packages. If these changes should not result in a new version, you're good to go. If these changes should result in a version bump, you need to add a changeset.
This PR includes no changesets
When changesets are added to this PR, you'll see the packages that this PR includes changesets for and the associated semver types
dependenciesPull requests that update a dependency file
1 participant
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
3.5.1
->4.0.0
Release Notes
Azure/azure-functions-nodejs-library (@azure/functions)
v4.0.0
Compare Source
The new Node.js programming model is now Generally Available! 🎉 This changelog is meant as a detailed list of changes in the new version. See the official upgrade guide for a less detailed, more user-friendly list of the changes.
Added
function.json
files #569 and #480InvocationContext
andHttpRequest
to be constructed in test environments outside the Azure Functions runtimeChanged
(request, context)
is now(context, request)
#34context
object #204Context
toInvocationContext
context.done()
. We assume your function (async or sync) is done as soon as it returnscontext.executionContext
. You can findfunctionName
andretryContext
on the rootcontext
object insteadcontext.bindingDefinitions
in favor ofcontext.options
context.log
sub-methods (context.log.error
/context.log.warn
/etc.) in favor of methods on the rootcontext
object (context.error
/context.warn
/etc.). Also Remove theverbose
option in favor oftrace
anddebug
to match Node.js'sconsole
methodscontext.req
,context,res
, andcontext.bindings
. The primary input is always an argument to your function, the primary output is always the return value of your function, and everything else can be accessed oncontext.extraInputs
orcontext.extraOutputs
context.bindingMetadata
context.triggerMetadata
sys
propertyRequest
toHttpRequest
query
from typeHttpRequestQuery
to Node.js core typeURLSearchParams
HttpResponseSimple
/HttpResponseFull
/HttpResponse
types in favor ofHttpResponse
class andHttpResponseInit
interfacestatusCode
in favor ofstatus
end
,send
,sendStatus
, andjson
. These were callback methods based oncontext.done()
which is no longer supportedsetHeader
,header
,set
,getHeader
,get
,removeHeader
,type
) from base response object. You must useresponse.headers
for any header-related methodsheaders
from typeHttpRequestHeaders
/HttpResponseHeaders
to fetch standard typeHeaders
body
,rawBody
,bufferBody
, andparseFormBody()
in favor of fetch standard methodsarrayBuffer()
,blob()
,formData()
,json()
, andtext()
null
#388setup()
method. v4 of the programming model is automatically setup when you register any function from theapp
objectConfiguration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by Mend Renovate. View repository job log here.