Unverified Commit 40fc6074 authored by Lucio Maciel's avatar Lucio Maciel Committed by GitHub

Merge pull request #973 from RocketChat/new/login-with-linkedin

[NEW] Login with Linkedin (OAuth).
parents f9d6c822 df61f11e
...@@ -30,6 +30,7 @@ private const val TYPE_LOGIN_CAS = 1 ...@@ -30,6 +30,7 @@ private const val TYPE_LOGIN_CAS = 1
private const val TYPE_LOGIN_OAUTH = 2 private const val TYPE_LOGIN_OAUTH = 2
private const val SERVICE_NAME_GITHUB = "github" private const val SERVICE_NAME_GITHUB = "github"
private const val SERVICE_NAME_GOOGLE = "google" private const val SERVICE_NAME_GOOGLE = "google"
private const val SERVICE_NAME_LINKEDIN = "linkedin"
private const val SERVICE_NAME_GILAB = "gitlab" private const val SERVICE_NAME_GILAB = "gitlab"
class LoginPresenter @Inject constructor(private val view: LoginView, class LoginPresenter @Inject constructor(private val view: LoginView,
...@@ -142,8 +143,12 @@ class LoginPresenter @Inject constructor(private val view: LoginView, ...@@ -142,8 +143,12 @@ class LoginPresenter @Inject constructor(private val view: LoginView,
} }
} }
if (settings.isLinkedinAuthenticationEnabled()) { if (settings.isLinkedinAuthenticationEnabled()) {
view.enableLoginByLinkedin() val clientId = getOauthClientId(services, SERVICE_NAME_LINKEDIN)
totalSocialAccountsEnabled++ if (clientId != null) {
view.setupGoogleButtonListener(UrlHelper.getLinkedinOauthUrl(clientId, currentServer, state), state)
view.enableLoginByLinkedin()
totalSocialAccountsEnabled++
}
} }
if (settings.isMeteorAuthenticationEnabled()) { if (settings.isMeteorAuthenticationEnabled()) {
view.enableLoginByMeteor() view.enableLoginByMeteor()
......
...@@ -132,9 +132,19 @@ interface LoginView : LoadingView, MessageView, InternetView { ...@@ -132,9 +132,19 @@ interface LoginView : LoadingView, MessageView, InternetView {
/** /**
* Shows the "login by Linkedin" view if it is enable by the server settings. * Shows the "login by Linkedin" view if it is enable by the server settings.
*
* REMARK: We must set up the Linkedin button listener before enabling it [setupLinkedinButtonListener].
*/ */
fun enableLoginByLinkedin() fun enableLoginByLinkedin()
/**
* Setups the Linkedin button when tapped.
*
* @param linkedinUrl The Linkedin OAuth URL to authenticate with.
* @param state A random string generated by the app, which you'll verify later (to protect against forgery attacks).
*/
fun setupLinkedinButtonListener(linkedinUrl: String, state: String)
/** /**
* Shows the "login by Meteor" view if it is enable by the server settings. * Shows the "login by Meteor" view if it is enable by the server settings.
*/ */
......
...@@ -231,6 +231,13 @@ class LoginFragment : Fragment(), LoginView { ...@@ -231,6 +231,13 @@ class LoginFragment : Fragment(), LoginView {
button_linkedin.isClickable = true button_linkedin.isClickable = true
} }
override fun setupLinkedinButtonListener(linkedinUrl: String, state: String) {
button_linkedin.setOnClickListener {
startActivityForResult(context?.oauthWebViewIntent(linkedinUrl, state), REQUEST_CODE_FOR_OAUTH)
activity?.overridePendingTransition(R.anim.slide_up, R.anim.hold)
}
}
override fun enableLoginByMeteor() { override fun enableLoginByMeteor() {
button_meteor.isClickable = true button_meteor.isClickable = true
} }
......
...@@ -56,6 +56,17 @@ object UrlHelper { ...@@ -56,6 +56,17 @@ object UrlHelper {
fun getGoogleOauthUrl(clientId: String, serverUrl: String, state: String) = fun getGoogleOauthUrl(clientId: String, serverUrl: String, state: String) =
"https://accounts.google.com/o/oauth2/v2/auth?client_id=$clientId&redirect_uri=${removeTrailingSlash(serverUrl)}/_oauth/google?close&response_type=code&state=$state&scope=email%20profile" "https://accounts.google.com/o/oauth2/v2/auth?client_id=$clientId&redirect_uri=${removeTrailingSlash(serverUrl)}/_oauth/google?close&response_type=code&state=$state&scope=email%20profile"
/**
* Returns the Linkedin Oauth URL.
*
* @param clientId The Linkedin client ID.
* @param serverUrl The server URL.
* @param state An unguessable random string used to protect against forgery attacks.
* @return The Linkedin Oauth URL.
*/
fun getLinkedinOauthUrl(clientId: String, serverUrl: String, state: String) =
"https://www.linkedin.com/oauth/v2/authorization?response_type=code&client_id=$clientId&redirect_uri=${removeTrailingSlash(serverUrl)}/_oauth/linkedin?close&state=$state"
/** /**
* Returns the Gitlab Oauth URL. * Returns the Gitlab Oauth URL.
* *
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment