5.0.0 • Published 1 year ago

@koa/cors v5.0.0

Weekly downloads
295,010
License
MIT
Repository
github
Last release
1 year ago

@koa/cors

NPM version Node.js CI Test coverage npm download

Cross-Origin Resource Sharing(CORS) for koa

Installation

$ npm install @koa/cors --save

Quick start

Enable cors with default options:

  • origin: request Origin header
  • allowMethods: GET,HEAD,PUT,POST,DELETE,PATCH
const Koa = require('koa');
const cors = require('@koa/cors');

const app = new Koa();
app.use(cors());

cors(options)

/**
 * CORS middleware
 *
 * @param {Object} [options]
 *  - {String|Function(ctx)} origin `Access-Control-Allow-Origin`, default is '*'
 *    If `credentials` set and return `true, the `origin` default value will set to the request `Origin` header
 *  - {String|Array} allowMethods `Access-Control-Allow-Methods`, default is 'GET,HEAD,PUT,POST,DELETE,PATCH'
 *  - {String|Array} exposeHeaders `Access-Control-Expose-Headers`
 *  - {String|Array} allowHeaders `Access-Control-Allow-Headers`
 *  - {String|Number} maxAge `Access-Control-Max-Age` in seconds
 *  - {Boolean|Function(ctx)} credentials `Access-Control-Allow-Credentials`, default is false.
 *  - {Boolean} keepHeadersOnError Add set headers to `err.header` if an error is thrown
 *  - {Boolean} secureContext `Cross-Origin-Opener-Policy` & `Cross-Origin-Embedder-Policy` headers.', default is false
 *  - {Boolean} privateNetworkAccess handle `Access-Control-Request-Private-Network` request by return `Access-Control-Allow-Private-Network`, default to false
 * @return {Function} cors middleware
 * @api public
 */

Breaking change between 5.0 and 4.0

The default origin is set to *, if you want to keep the 4.0 behavior, you can set the origin handler like this:

app.use(cors({
  origin(ctx) {
    return ctx.get('Origin') || '*';
  },
}));

License

MIT

Contributors

fengmk2dead-horseomsmithjonathanongAlphaWongcma-skedulo
CleberRossierikfriedj-waaangltomeslfrenedamatthewmueller
PlasmaPowerswainTyrealHuxg-wanglishengzxcmcohen75

This project follows the git-contributor spec, auto updated at Sat Oct 08 2022 21:35:10 GMT+0800.

@kbox/server@sprucelabs/spruce-skill-serverwidget-like-button-testnuggets-creditssky-search-api@nuragic/apollo-server-koayoukuohao-accounts@framework100500/platform-koa@atlaslabs/koa-switch-loaderfeed-simulcastboardgame.ioju@deity/falcon-serverct-webservice@rappopo/cuk-http@chialab/rna-web-server@biqoro/serverdatoapielement-ui-color-settingrugo-core@spacefill/gibbon-mail-test@nodesh/nodesh@textury/arlocaldotwallet-express-exampletanzhou-ajaxdemo@bitstreamy/api@service-exchange/server@infinitebrahmanuniverse/nolb-_koaclymenedrafterbitmyfiteco-apiframework-backend@fed123/fe-plugin-monitor@everything-registry/sub-chunk-523koa-dev-boilerplatelyr-cli@tracktile/veritastarattarat-servert9tpcordernum_react_apisvg-path-length-servicetest-coreatest-fake-serverteaching-apistea-restwechaty-puppet-miniwaft-cliwaline-vercelwampark-devkitwhistle.mockyawhistle.devtoolwhistle.easy-mockxj-interface-frameworkxiaoyaoji-mock-serverxiaoyaoji-mock-server-cookiexmockerwukong-clisuper-search-hubtech_rp_apisteamer-koastrapistrapi-boing-globalstrapi-manager-core-strapistrapi-maxiphytestapi6-mockapitest-quick-create-demoswan-toolkitswagger2-koasy-sparrowthe-rangtiangang-audittigovite-plugin-koa-mockvoox-waline-vercelvite-plugin-fsvaye_koa_corevaivue-cli-plugin-vssr@ditojs/server@djmax/boardgame.io@creatajs/faucet@cran/gql.koa@cran/koa.core@cran/lib.koa.core@ctbto/oidc-provider@cs125/chitter@cs125/element-tracker@cs125/githubgrader@cs125/helpable@cs125/jsp@cs125/mace@cs125/personable@cs125/questionable@cs125/questioner@cs125/schedulable@cs125/shareable@cs125/stumper@cs124/cors@ctl-bluesquad-components/top-ui@crystallize/node-service-api-router@condomi/helpers
5.0.0

1 year ago

3.4.3

3 years ago

3.4.2

3 years ago

4.0.0

3 years ago

3.4.0

3 years ago

3.4.1

3 years ago

3.3.0

3 years ago

3.2.0

3 years ago

3.1.0

5 years ago

3.0.0

6 years ago

2.2.3

6 years ago

2.2.2

7 years ago

2.2.1

8 years ago