2017 © Pedro PelĂĄez
 

symfony-bundle oauth

A bundle to wrap FOSOauthServerBundle and provide oauth to APIs

image

aescarcha/oauth

A bundle to wrap FOSOauthServerBundle and provide oauth to APIs

  • Thursday, November 24, 2016
  • by aEscarcha
  • Repository
  • 1 Watchers
  • 1 Stars
  • 20 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Installation

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:, (*1)

$ composer require aescarcha/oauth "~1"

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation., (*2)

Step 2: Install Requirements

composer require friendsofsymfony/rest-bundle
composer require jms/serializer-bundle
composer require nelmio/api-doc-bundle
composer require friendsofsymfony/user-bundle
composer require aescarcha/user-bundle dev-master
composer require friendsofsymfony/oauth-server-bundle

Step 3: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the app/AppKernel.php file of your project:, (*3)

<?php
// app/AppKernel.php

// ...
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new FOS\RestBundle\FOSRestBundle(),
            new JMS\SerializerBundle\JMSSerializerBundle(),
            new Nelmio\ApiDocBundle\NelmioApiDocBundle(),
            new FOS\UserBundle\FOSUserBundle(),
            new Aescarcha\UserBundle\AescarchaUserBundle(),
            new Aescarcha\OauthServerBundle\AescarchaOauthServerBundle(),
        );

        // ...
    }

    // ...
}

Step 4: Configure the Bundle

Enable the routes in app/config/routing.yml, (*4)

NelmioApiDocBundle:
    resource: "@NelmioApiDocBundle/Resources/config/routing.yml"
    prefix:   /api/doc

aescarcha_oauth_server:
    resource: "@AescarchaOauthServerBundle/Resources/config/routing.yml"
    prefix:   /

Configure the bundles in app/config/config.yml, (*5)

# app/config/config.yml
nelmio_api_doc: ~

fos_rest:
    routing_loader:
        default_format: json                            # All responses should be JSON formated
        include_format: false                           # We do not include format in request, so that all responses
                                                        # will eventually be JSON formated

body_listener:                                          # Decode full json bodies
    decoders:
         son: fos_rest.decoder.json


fos_user:
    db_driver: orm
    firewall_name: oauth_token                          # Seems to be used when registering user/reseting password,
                                                        # but since there is no "login", as so it seems to be useless in
                                                        # our particular context, but still required by "FOSUserBundle"
    user_class: Aescarcha\UserBundle\Entity\User

fos_oauth_server:
    db_driver:           orm
    client_class:        Aescarcha\OauthServerBundle\Entity\Client
    access_token_class:  Aescarcha\OauthServerBundle\Entity\AccessToken
    refresh_token_class: Aescarcha\OauthServerBundle\Entity\RefreshToken
    auth_code_class:     Aescarcha\OauthServerBundle\Entity\AuthCode
    service:
        user_provider: fos_user.user_manager             # This property will be used when valid credentials are given to load the user upon access token creation

Add this to app/config/security.yml, (*6)

security:
    encoders:
        FOS\UserBundle\Model\UserInterface: sha512

    providers:
        fos_userbundle:
            id: fos_user.user_provider.username        # fos_user.user_provider.username_email does not seem to work (OAuth-spec related ("username + password") ?)
    firewalls:
        oauth_token:                                   # Everyone can access the access token URL.
            pattern: ^/oauth/v2/token
            security: false

Testing

To test this bundle, you need to download and enable the following bundles, (*7)

"doctrine/doctrine-fixtures-bundle": "^2.3",
"liip/functional-test-bundle": "^1.6"

$bundles[] = new Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle();
$bundles[] = new Liip\FunctionalTestBundle\LiipFunctionalTestBundle();

And I recommend using this config in config_test.yml to use sqlite, (*8)

doctrine:
    dbal:
        default_connection: default
        connections:
            default:
                driver:   pdo_sqlite
                path:     %kernel.cache_dir%/test.db

liip_functional_test:
    cache_sqlite_db: true

The Versions

24/11 2016

dev-master

9999999-dev

A bundle to wrap FOSOauthServerBundle and provide oauth to APIs

  Sources   Download

MIT

The Requires

  • php >=5.5.9

 

by Álvaro Escarcha

oauth symfony

14/09 2016

dev-develop

dev-develop

A bundle to wrap FOSOauthServerBundle and provide oauth to APIs

  Sources   Download

MIT

The Requires

  • php >=5.5.9

 

by Álvaro Escarcha

oauth symfony

14/09 2016

v1.0

1.0.0.0

A bundle to wrap FOSOauthServerBundle and provide oauth to APIs

  Sources   Download

MIT

The Requires

  • php >=5.5.9

 

by Álvaro Escarcha

oauth symfony