bartlomiejbeta/api-scope-bundle

Simple API query string scope recognizer

Installs: 7 342

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 1

Open Issues: 1

Type:symfony-bundle

v3.0.1 2018-11-16 13:42 UTC

This package is auto-updated.

Last update: 2024-11-20 23:01:00 UTC


README

This Symfony bundle aims to provide simple serialization group recognize from query string (with basic security check if you need it).

Build Status

Installation

1. Install via composer:
composer require bartlomiejbeta/api-scope-bundle
2. Register bundle in AppKernel:
public function registerBundles()
{
    $bundles = array(
        // ...
		new BartB\APIScopeBundle\APIScopeBundle(),
    );
}
3. Configure in config.yml:
api_scope:
    scopes:
        api.get_item: #route name
            always_included: #will be always included to scopes bag
                - 'first_always_included_group'
                - 'second_always_included_group'
            supported_key_map:
                external1: { internal_name: 'scope.internal_name1'} #if `external1` will be in the query string than `scope.internal_name1` will be in the scopes bag
                external2:
                    internal_name: 'scope.internal_name2'
                    security: 'can-add-external2-scope' # security voter (check symfony security voter) attribution name (to check if scope can be applied)

Usage

1. Simple

/**
* @ScopeConverter()
* @Rest\Route("/api/item", name="api.get_item")
*/
public function getCarCollection(Request $request, ScopeCollection $scopeCollection): Response
{
	$view = $this->view($scopeCollection, Response::HTTP_OK);
	
	$scopesFromQueryString = $scopeCollection->getScopes()
	
	return $this->handleView($view);
}
example request:
.../api/item?with[]=external1
example response:
{"scopes":["first_always_included_group","second_always_included_group","scope.internal_name1"]}

2. Configured

/**
* @ScopeConverter(value="scopes",queryString="scope")
* @Rest\Route("/api/item", name="api.get_item")
*/
public function getCarCollection(Request $request, ScopeCollection $scopes): Response
{
	$view = $this->view($scope,Response::HTTP_OK);
		
	scopesFromQueryString = $scopeCollection->getScopes()
		
	return $this->handleView($view);
}
example request:
.../api/item?scope[]=external1&scope[]=external2
example response:
{"scopes":["first_always_included_group","second_always_included_group","scope.internal_name1","scope.internal_name2"]}