PlugCors
A CORS Plug
Usage:
plug PlugCors, origins: ["test.origin.test", "*.domain.com"], methods: ["GET", "POST"], headers: ["Authorization"]
If using with Phoenix, make sure to define the plug above your router. This is so the plug correctly responds to the OPTIONS requests the browser makes for CORS and prevents 404 responses to the browser’s CORS requests.
defmodule App.Endpoint do
#the rest of the plugs defined in App.Endpoint
plug PlugCors, origins: ["*"]
plug :router, App.Router
end
You can also define the parameters inside of your elixir config instead if you wish. Parameters defined directly on the plug take precedence over the ones in config
config :plug_cors,
origins: ["test.origin.test", "*.domain.com"],
methods: ["GET", "POST"],
headers: ["Authorization"]
Parameters:
origins: A list of allowed origins or “*“ for all origins. Default: “*“. Can add use wildcards domains such as “*.domain.com” to match on the domain and all it’s sub domains
methods: A list of allowed HTTP methods. Default: ["GET", "HEAD", "POST", "OPTIONS", "PUT", "PATCH", "DELETE"]
headers: A list of additionally allowed HTTP headers. These are in addition to ‘PlugCors.Preflight.default_accept_headers’. Default: []
expose_headers: A list of headers to expose to the browser via the “Access-Control-Expose-Headers” header. Default: [] (Will not output header)
max_age: The max cache age of the response in seconds “Access-Control-Max-Age” header. Default: 0 (Will not output header)
- supports_credentials: Whether or not to allow cookies with requests “Access-Control-Allow-Credentials” header. Default: false (Will not output header)
Summary
call(conn, config) | |
init(opts) |