ekreative / redmine_login
Login to symfony using redmine as user provider
Installs: 606
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 3
Forks: 6
Open Issues: 1
Type:symfony-bundle
Requires
- php: >=7.1
- ext-json: *
- guzzlehttp/guzzle: ^6.2
- mcfedr/json-form: ^4.4
- symfony/form: ^3.0|^4.0
- symfony/framework-bundle: ^3.0|^4.0
Requires (Dev)
- phpunit/phpunit: ^5.3
- symfony/monolog-bundle: ^3.0|^2.4
- symfony/phpunit-bridge: ^4.2
README
Install
composer require ekreative/redmine_login
Kernel
new Ekreative\RedmineLoginBundle\EkreativeRedmineLoginBundle()
Parameters
parameters:
redmine: 'http://www.redmine.org'
Config
ekreative_redmine_login:
redmine: %redmine%
Routing
ekreative_redmine_login:
resource: "@EkreativeRedmineLoginBundle/Resources/config/routing.yml"
Security
security:
providers:
webservice:
id: ekreative_redmine_login.provider
firewalls:
unsec:
pattern: ^/login$
security: false
secured_area:
pattern: ^/
anonymous:
simple_form:
authenticator: ekreative_redmine_login.authenticator
check_path: login_check
login_path: login
username_parameter: login[username]
password_parameter: login[password]
simple_preauth:
authenticator: ekreative_redmine_login.api_authenticator
logout:
path: /logout
access_control:
- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, roles: ROLE_REDMINE }
Security
You can secure your own routes using two roles
- ROLE_REDMINE
- ROLE_REDMINE_ADMIN
Make Request
$projects = json_decode($this->get('ekreative_redmine_login.client_provider')->get($this->getUser())->get('projects.json')->getBody(), true)['projects']
Login as api user
POST /login HTTP/1.1
Content-Type: application/json
{
"login": {
"username": "username",
"password": "password"
}
}
Response
200 OK
{
"user": {
"id": 1,
"username": "username",
"firstName": "Name",
"lastName": "Last",
"email": "user@domin.com",
"createdAt": "2000-01-01T00:00:00+00:00",
"lastLoginAt": "2000-01-01T00:00:00+00:00",
"apiKey": "your_api_key",
"status": 1
}
}
Logged in:
GET /admin HTTP/1.1
Host: 127.0.0.1:8000
X-API-Key: your_api_key
Custom user class
If you want to use a custom user class then its very easy! There are two ways
-
Either override the parameter
ekreative_redmine_login.user.class
with the name of your own class that extendsRedmineUser
. -
Or override the service
ekreative_redmine_login.user_factory
with a service that implementsRedmineUserFactoryInterface
. You will want to do this if you are using Doctrine.
RedmineUser
contains all the annotations for use with Doctrine, so its super simple to store users in the database.
Api Doc
If you want the api doc to be listed then use NelmioApiDocBundle
Kernel
new Nelmio\ApiDocBundle\NelmioApiDocBundle()
Routing
NelmioApiDocBundle:
resource: "@NelmioApiDocBundle/Resources/config/routing.yml"
prefix: /api/doc
Security
Replace the standard unsec
unsec:
pattern: ^/(login$|api/doc)
security: false