Download the PHP package ekreative/redmine_login without Composer
On this page you can find all versions of the php package ekreative/redmine_login. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Table of contents
Download ekreative/redmine_login
More information about ekreative/redmine_login
Files in ekreative/redmine_login
Download ekreative/redmine_login
More information about ekreative/redmine_login
Files in ekreative/redmine_login
Vendor ekreative
Package redmine_login
Short Description Login to symfony using redmine as user provider
License MIT
Package redmine_login
Short Description Login to symfony using redmine as user provider
License MIT
Please rate this library. Is it a good library?
Informations about the package redmine_login
Redmine Login
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": "[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
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
All versions of redmine_login with dependencies
PHP Build Version
Package Version
Requires
php Version
>=7.1
ext-json Version *
guzzlehttp/guzzle Version ^6.2
mcfedr/json-form Version ^4.4
symfony/framework-bundle Version ^3.0|^4.0
symfony/form Version ^3.0|^4.0
ext-json Version *
guzzlehttp/guzzle Version ^6.2
mcfedr/json-form Version ^4.4
symfony/framework-bundle Version ^3.0|^4.0
symfony/form Version ^3.0|^4.0
The package ekreative/redmine_login contains the following files
Loading the files please wait ....