friendsofcat / github-team-auth
Git hub log in tool
Requires
- php: >=5.5.9
- graham-campbell/github: ^8.6
- illuminate/support: 6.*
- knplabs/github-api: ^2.9
- laravel/socialite: ^4.0
- php-http/guzzle6-adapter: ^1.1
Requires (Dev)
- fzaninotto/faker: ~1.4
- mockery/mockery: ~1.0
- nunomaduro/collision: ~1.1
- orchestra/testbench-browser-kit: ~3.4
- php-coveralls/php-coveralls: ^2.1
- phpunit/phpunit: ~8.0
- squizlabs/php_codesniffer: ^3.3
This package is auto-updated.
Last update: 2024-11-17 22:35:00 UTC
README
Overview
The GitHubLogin is a Laravel package which uses the socialite(https://github.com/laravel/socialite) to login a user by getting his github user account and permission. It basically get a github account and validate if the use is part of the expected organization and teams, and send a event with the user data. The expected organization and teams must be populated in database, which is possible to do by UI (See the UI section for more information).
Requirements
"require": {
"php": ">=5.5.9",
"illuminate/support": "5.*",
"laravel/socialite": "^3.0@dev",
"knplabs/github-api": "^2.9",
"php-http/guzzle6-adapter": "^1.1",
"graham-campbell/github": "^7.4"
}
Install
Composer install
composer require friendsofcat/github-team-auth
Publish config File
php artisan vendor:publish
Publish config file
php artisan vendor:publish --provider="Friendsofcat\GitHubTeamAuth\GitHubTeamAuthProvider" --tag='github_team_auth:config'
The config file has only onw parameter, team_table_name, which define the name of the table in database for githubteams names, the default value is 'teams'
The config file has only onw parameter, custom_redirect, which define where we should redirect.
Publish migrations
php artisan vendor:publish --provider="Friendsofcat\GitHubTeamAuth\GitHubTeamAuthProvider" --tag='github_team_auth:migrations'
Publish views
php artisan vendor:publish --provider="Friendsofcat\GitHubTeamAuth\GitHubTeamAuthProvider" --tag='github_team_auth:views'
Edit app/config/service.php to add the code below
'github' => [
'client_id' => env('GITHUB_CLIENT_ID'),
'client_secret' => env('GITHUB_CLIENT_SECRET'),
'redirect' => 'https://cat-quality-service.test/auth/github/callback',
],
Env file For service.php configurations is necessary to inform:
- GITHUB_CLIENT_ID
- GITHUB_CLIENT_SECRET
- redirect ( whihc must be https://{{APP_NAME}}/auth/github/callback ).
You can get all these parameters after register the app in the github callback feature.
View to Manage Organization and orgs
https://{domain}/admin/github-team-auth
This is the dashboard page which list all the team and orgs from this page you are able to delete an organization or team. Also you can navaguete to create team or create organization screen.
https://{domain}/admin/github-team-auth/add/team
This page was design for add a new team, display the team possibilities using the github token storaged in cache when user logged in. Also allow the user add a tag for label the access level of team, it can be add by the 'acl' field.
https://{domain}/admin/github-team-auth/add/org
This page was design for add a new team, display the organization possibilities using the github token storaged in cache when user logged in.
Event
In the end of process the user will be login and an event will be trigger. This event has to public parameters:
-
user_github_object ( \Laravel\Socialite\Two\User )
Which contain all the user information.
-
user_team_array ( array )
An array with all the teams which this user is part of.
HTML
You must add the git hub loggin button in your login page, as the example below:
<a class="btn mb-2 btn-secondary" href="{{ route('git_auth') }}">
<i class="fa fa-github"></i> GitHub
</a>
@if ($errors->has('github'))
<span class="help-block alert alert-dark">
<strong>{{ $errors->first('github') }}</strong>
</span>
@endif
Chicken - Egg dilemma
For add a new Organization/Team the user need to be logged at the system, but for loggin the system must have some vaid organization and team in DB. To solve this problem create a migration and insert the basic organization and team.