NAME
Dancer2::Plugin::Auth::OAuth - OAuth for your Dancer2 app
SYNOPSIS
# just 'use' the plugin, that's all.
use Dancer2::Plugin::Auth::OAuth;
DESCRIPTION
Dancer2::Plugin::Auth::OAuth is a Dancer2 plugin which tries to make OAuth authentication easy.
The module is highly influenced by Plack::Middleware::OAuth and Dancer 1 OAuth modules, but unlike the Dancer 1 versions, this plugin only needs configuration (look mom, no code needed!). It automatically sets up the needed routes (defaults to /auth/$provider
and /auth/$provider/callback
). So if you define the Twitter provider in your config, you should automatically get /auth/twitter
and /auth/twitter/callback
.
After a successful OAuth dance, the user info is stored in the session. What you do with it afterwards is up to you.
CONFIGURATION
The plugin comes with support for Facebook, Google, Twitter, GitHub, Stack Exchange and LinkedIn (other providers aren't hard to add, send me a pull request when you add more!)
All it takes to use OAuth authentication for a given provider, is to add the configuration for it.
The YAML below shows all available options.
plugins:
"Auth::OAuth":
prefix: /auth [*]
success_url: / [*]
error_url: / [*]
providers:
Facebook:
tokens:
client_id: your_client_id
client_secret: your_client_secret
fields: id,email,name,gender,picture
Google:
tokens:
client_id: your_client_id
client_secret: your_client_secret
Twitter:
tokens:
consumer_key: your_consumer_token
consumer_secret: your_consumer_secret
Github:
tokens:
client_id: your_client_id
client_secret: your_client_secret
Stackexchange:
tokens:
client_id: your_client_id
client_secret: your_client_secret
key: your_key
site: stackoverflow
Linkedin:
tokens:
client_id: your_client_id
client_secret: your_client_secret
fields: id,num-connections,picture-url,email-address
VKontakte: # https://vk.com
tokens:
client_id: '...'
client_secret: '...'
fields: 'first_name,last_name,about,bdate,city,country,photo_max_orig,sex,site'
api_version: '5.8'
Odnoklassniki: # https://ok.ru
tokens:
client_id: your_client_id
client_secret: your_client_secret
application_key: your_application_key
method: 'users.getCurrentUser'
format: 'json'
fields: 'email,name,gender,birthday,location,uid,pic_full'
MailRU:
tokens:
client_id: your_client_id
client_private: your_client_private
client_secret: your_client_secret
method: 'users.getInfo'
format: 'json'
secure: 1
Yandex:
tokens:
client_id: your_client_id
client_secret: your_client_secret
format: 'json'
[*] default value, may be omitted.
AUTHOR
Menno Blom <blom@cpan.org>
COPYRIGHT
Copyright 2014- Menno Blom
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.