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
consthttp=require('http')constfortune=require('fortune')constfortuneHTTP=require('fortune-http')constmicroApiSerializer=require('fortune-micro-api')constoptions={entryPoint: 'https://example.com',externalContext: '/context.jsonld'}// `instance` is an instance of Fortune.js.constlistener=fortuneHTTP(instance,{serializers: [// The `options` object here is required.[microApiSerializer,options]]})// The listener function may be used as a standalone server, or// may be composed as part of a framework.constserver=http.createServer((request,response)=>// When an external context is set, it should be handled externally.(request.url.indexOf(options.externalContext)===0 ?
microApiSerializer.showExternalContext(response,options) :
listener(request,response)).catch(error=>{/* error logging */}))server.listen(8080)
The options object is as follows:
entryPoint: URI to the entry point. Required.
externalContext: refer to the @context instead of embedding. Recommended. This requires some additional setup, so it's disabled by default. This should be valued by a URI to the external context.
inflectType: convert record type name to PascalCase in the payload. Default: true.
reverseFields: An object keyed by field names, which should use the @reverse property.
contexts: An array valued by URIs to external contexts.
Inherited options:
bufferEncoding: which encoding type to use for input buffer fields.
maxLimit: maximum number of records to show per page.
includeLimit: maximum depth of fields per include.
uriBase64: encode URIs in base64 to discourage clients from tampering with the URI.
castId: try to cast string IDs to numbers if possible.
MessagePack
Instead of using JSON as a serialization format, it can optionally use MessagePack instead, with an unregistered media type application/x-micro-api. It has the advantage of serializing dates and buffers properly.
constmicroApiSerializer=require('fortune-micro-api')// Alternative serializer with unregistered media type.constmicroApiMsgPack=microApiSerializer.msgpack