This repository has been archived on 2025-01-19. You can view files and clone it, but cannot push or open issues or pull requests.
drupalcampbristol/web/vendor/asm89/stack-cors/README.md

63 lines
1.8 KiB
Markdown
Raw Normal View History

# Stack/Cors
Library and middleware enabling cross-origin resource sharing for your
http-{foundation,kernel} using application. It attempts to implement the
2017-04-13 14:53:35 +00:00
[W3C Recommendation] for cross-origin resource sharing.
2017-04-13 14:53:35 +00:00
[W3C Recommendation]: http://www.w3.org/TR/cors/
Master [![Build Status](https://secure.travis-ci.org/asm89/stack-cors.png?branch=master)](http://travis-ci.org/asm89/stack-cors)
## Installation
Require `asm89/stack-cors` using composer.
## Usage
2017-04-13 14:53:35 +00:00
This package can be used as a library or as [stack middleware].
[stack middleware]: http://stackphp.com/
### Example: using the library
```php
<?php
2017-04-13 14:53:35 +00:00
use Asm89\Stack\CorsService;
2017-04-13 14:53:35 +00:00
$cors = new CorsService(array(
'allowedHeaders' => array('x-allowed-header', 'x-other-allowed-header'),
'allowedMethods' => array('DELETE', 'GET', 'POST', 'PUT'),
'allowedOrigins' => array('localhost'),
'exposedHeaders' => false,
'maxAge' => false,
'supportsCredentials' => false,
));
2017-04-13 14:53:35 +00:00
$cors->addActualRequestHeaders(Response $response, $origin);
$cors->handlePreflightRequest(Request $request);
$cors->isActualRequestAllowed(Request $request);
$cors->isCorsRequest(Request $request);
$cors->isPreflightRequest(Request $request);
```
2017-04-13 14:53:35 +00:00
## Example: using the stack middleware
```php
<?php
2017-04-13 14:53:35 +00:00
use Asm89\Stack\Cors;
2017-04-13 14:53:35 +00:00
$app = new Cors($app, array(
// you can use array('*') to allow any headers
'allowedHeaders' => array('x-allowed-header', 'x-other-allowed-header'),
2017-04-13 14:53:35 +00:00
// you can use array('*') to allow any methods
'allowedMethods' => array('DELETE', 'GET', 'POST', 'PUT'),
2017-04-13 14:53:35 +00:00
// you can use array('*') to allow requests from any origin
'allowedOrigins' => array('localhost'),
'exposedHeaders' => false,
'maxAge' => false,
'supportsCredentials' => false,
));
```