summaryrefslogtreecommitdiff
path: root/doc/administration/integration/oauth_provider.md
diff options
context:
space:
mode:
Diffstat (limited to 'doc/administration/integration/oauth_provider.md')
-rw-r--r--doc/administration/integration/oauth_provider.md80
1 files changed, 80 insertions, 0 deletions
diff --git a/doc/administration/integration/oauth_provider.md b/doc/administration/integration/oauth_provider.md
new file mode 100644
index 00000000000..5f8bb57365c
--- /dev/null
+++ b/doc/administration/integration/oauth_provider.md
@@ -0,0 +1,80 @@
+# GitLab as OAuth2 authentication service provider
+
+This document is about using GitLab as an OAuth authentication service provider
+to sign in to other services.
+
+If you want to use other OAuth authentication service providers to sign in to
+GitLab, please see the [OAuth2 client documentation](../api/oauth2.md).
+
+## Introduction to OAuth
+
+[OAuth] provides to client applications a 'secure delegated access' to server
+resources on behalf of a resource owner. In fact, OAuth allows an authorization
+server to issue access tokens to third-party clients with the approval of the
+resource owner, or the end-user.
+
+OAuth is mostly used as a Single Sign-On service (SSO), but you can find a
+lot of different uses for this functionality. For example, you can allow users
+to sign in to your application with their GitLab.com account, or GitLab.com
+can be used for authentication to your GitLab instance
+(see [GitLab OmniAuth](gitlab.md)).
+
+The 'GitLab Importer' feature is also using the OAuth protocol to give access
+to repositories without sharing user credentials to your GitLab.com account.
+
+---
+
+GitLab supports two ways of adding a new OAuth2 application to an instance. You
+can either add an application as a regular user or add it in the admin area.
+What this means is that GitLab can actually have instance-wide and a user-wide
+applications. There is no difference between them except for the different
+permission levels they are set (user/admin).
+
+## Adding an application through the profile
+
+In order to add a new application via your profile, navigate to
+**Profile Settings > Applications** and select **New Application**.
+
+![New OAuth application](img/oauth_provider_user_wide_applications.png)
+
+---
+
+In the application form, enter a **Name** (arbitrary), and make sure to set up
+correctly the **Redirect URI** which is the URL where users will be sent after
+they authorize with GitLab.
+
+![New OAuth application form](img/oauth_provider_application_form.png)
+
+---
+
+When you hit **Submit** you will be provided with the application ID and
+the application secret which you can then use with your application that
+connects to GitLab.
+
+![OAuth application ID and secret](img/oauth_provider_application_id_secret.png)
+
+---
+
+## OAuth applications in the admin area
+
+To create an application that does not belong to a certain user, you can create
+it from the admin area.
+
+![OAuth admin_applications](img/oauth_provider_admin_application.png)
+
+---
+
+## Authorized applications
+
+Every application you authorized to use your GitLab credentials will be shown
+in the **Authorized applications** section under **Profile Settings > Applications**.
+
+![Authorized_applications](img/oauth_provider_authorized_application.png)
+
+---
+
+As you can see, the default scope `api` is used, which is the only scope that
+GitLab supports so far. At any time you can revoke any access by just clicking
+**Revoke**.
+
+[oauth]: http://oauth.net/2/ "OAuth website"