UNPKG

actionhero

Version:

actionhero.js is a multi-transport API Server with integrated cluster capabilities and delayed tasks

102 lines (100 loc) 3.74 kB
exports.default = { servers: { web: function(api){ return { enabled: true, // HTTP or HTTPS? secure: false, // Passed to https.createServer if secure=true. Should contain SSL certificates serverOptions: {}, // Port or Socket Path port: process.env.PORT || 8080, // Which IP to listen on (use '0.0.0.0' for all; '::' for all on ipv4 and ipv6) // Set to `null` when listening to socket bindIP: '0.0.0.0', // Any additional headers you want actionhero to respond with httpHeaders : { 'X-Powered-By' : api.config.general.serverName, 'Access-Control-Allow-Origin' : '*', 'Access-Control-Allow-Methods': 'HEAD, GET, POST, PUT, PATCH, DELETE, OPTIONS, TRACE', 'Access-Control-Allow-Headers': 'Content-Type', }, // Route that actions will be served from; secondary route against this route will be treated as actions, // IE: /api/?action=test == /api/test/ urlPathForActions : 'api', // Route that static files will be served from; // path (relative to your project root) to serve static content from // set to `null` to disable the file server entirely urlPathForFiles : 'public', // When visiting the root URL, should visitors see 'api' or 'file'? // Visitors can always visit /api and /public as normal rootEndpointType : 'file', // simple routing also adds an 'all' route which matches /api/:action for all actions simpleRouting : true, // queryRouting allows an action to be defined via a URL param, ie: /api?action=:action queryRouting : true, // The header which will be returned for all flat file served from /public; defined in seconds flatFileCacheDuration : 60, // How many times should we try to boot the srever? // This might happen if the port is in use by another process or the socketfile is claimed bootAttempts: 1, // Settings for determining the id of an http(s) request (browser-fingerprint) fingerprintOptions : { cookieKey: 'sessionID', toSetCookie: true, onlyStaticElements: false, settings: { path: '/', expires: 3600000, } }, // Options to be applied to incoming file uploads. // More options and details at https://github.com/felixge/node-formidable formOptions: { uploadDir: '/tmp', keepExtensions: false, maxFieldsSize: 1024 * 1024 * 100 }, // Should we pad JSON responses with whitespace to make them more human-readable? // set to null to disable padding: 2, // Options to configure metadata in responses metadataOptions: { serverInformation: true, requesterInformation: true }, // When true, returnErrorCodes will modify the response header for http(s) clients if connection.error is not null. // You can also set connection.rawConnection.responseHttpCode to specify a code per request. returnErrorCodes: true } } } } exports.production = { servers: { web: function(api){ return { padding: null, metadataOptions: { serverInformation: false, requesterInformation: false } } } } } exports.test = { servers: { web: function(api){ return { secure: false, port: 18080, matchExtensionMime: true, metadataOptions: { serverInformation: true, requesterInformation: true } } } } }