composer require ekreative/redmine_login
new Ekreative\RedmineLoginBundle\EkreativeRedmineLoginBundle()
parameters:
redmine: 'http://www.redmine.org'
ekreative_redmine_login:
redmine: %redmine%
ekreative_redmine_login:
resource: "@EkreativeRedmineLoginBundle/Resources/config/routing.yml"
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 }
You can secure your own routes using two roles
- ROLE_REDMINE
- ROLE_REDMINE_ADMIN
$projects = json_decode($this->get('ekreative_redmine_login.client_provider')->get($this->getUser())->get('projects.json')->getBody(), true)['projects']
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": "[email protected]",
"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
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.
If you want the api doc to be listed then use NelmioApiDocBundle
new Nelmio\ApiDocBundle\NelmioApiDocBundle()
NelmioApiDocBundle:
resource: "@NelmioApiDocBundle/Resources/config/routing.yml"
prefix: /api/doc
Replace the standard unsec
unsec:
pattern: ^/(login$|api/doc)
security: false