Skip to main content

Social Auth backend for GSIS

Project description

Social Auth GSIS

Python Social Auth backend for the OAuth 2.0 for GSIS, intended for use in Django applications.

Requirements

  • Python 3.8, or newer
  • Django 3.2, or newer

Installation

Install the social-auth-gsis from PyPI using your favorite package manager.

pip

pipi install social-auth-gsis

Poetry

poetry add social-auth-gsis

Usage

To get the GSIS authentication package working with a Django application, both settings and URLs need to be configured.

Settings

The best place to get started with integrating Social Auth GSIS in a Django project is the settings.

First, the social_django app needs to be added in the INSTALLED_APPS setting of your Django application:

INSTALLED_APPS = [
    # ...the rest of installed apps
    "social_django",
]

Next, social_django.middleware.SocialAuthExceptionMiddleware needs to be included in MIDDELWARE, right below the django.middleware.clickjacking.XFrameOptionsMiddleware:

MIDDLEWARE = [
    # ...the rest of middleware
    "django.middleware.clickjacking.XFrameOptionsMiddleware",
    "social_django.middleware.SocialAuthExceptionMiddleware",
]

In order to only allow creation of users through the social auth pipeline, the SOCIAL_AUTH_PIPELINE Django Social Auth setting needs to be set to the following value:

SOCIAL_AUTH_PIPELINE = (
    "social_core.pipeline.social_auth.social_details",
    "social_core.pipeline.social_auth.social_uid",
    "social_core.pipeline.social_auth.auth_allowed",
    "social_auth_gsis.pipeline.social_auth.social_user",
    "social_core.pipeline.social_auth.associate_user",
    "social_core.pipeline.social_auth.load_extra_data",
    "social_core.pipeline.user.user_details",
)

To configure the credentials and redirect URLs of a Social Auth GSIS backend the appropriate settings need to be set as well:

SOCIAL_AUTH_GSIS_KEY = "oauth2_client_key"
SOCIAL_AUTH_GSIS_SECRET = "oauth2_client_secret"
SOCIAL_AUTH_GSIS_REDIRECT_URL = "https://yourapp.local/authorize/gsis/"

Finally, the intended backends should be included in the AUTHENTICATION_BACKENDS setting:

AUTHENTICATION_BACKENDS = (
    "social_auth_gsis.backends.GSISOAuth2",
    # ...the rest of backends included
)

URLs

The URLs of Django Social Auth are required to be included also, in order to authenticate users redirected from GSIS' auth:

from django.urls import include, path
from social_django import views as social_django_views


urlpatterns = [
    path("auth/", include("social_django.urls", namespace="social")),
    # ...the rest of URL patterns
]

The ability to explicitly set the backend to be used in a URL for authentication, is also possible:

urlpatterns = [
    path(
        "authorize/gsis/",
         social_django_views.complete,
        kwargs={"backend": "ktimatologio_gsis"},
        name="authorize",
    ),
    # ...the rest of URL patterns
]

Backends

The following social auth backends are available in social_auth_gsis.backends.

GSISOAuth2

Used for authentication of citizens. For testing purposes the GSISOAuth2Testing backend should be used instead. The following settings are required:

  • SOCIAL_AUTH_GSIS_KEY
  • SOCIAL_AUTH_GSIS_SECRET
  • SOCIAL_AUTH_GSIS_REDIRECT_URL

GSISOTPOAuth2

Used for authentication of citizens, requiring also OTP verification. For testing purposes the GSISOTPOAuth2Testing backend should be used instead. The following settings are required:

  • SOCIAL_AUTH_GSIS_OTP_KEY
  • SOCIAL_AUTH_GSIS_OTP_SECRET
  • SOCIAL_AUTH_GSIS_OTP_REDIRECT_URL

GSISPAOAuth2

Used for authentication of public sector employees (PA for Public Administration). For testing purposes the GSISPAOAuth2Testing backend should be used instead. The following settings are required:

  • SOCIAL_AUTH_GSIS_PA_KEY
  • SOCIAL_AUTH_GSIS_PA_SECRET
  • SOCIAL_AUTH_GSIS_PA_REDIRECT_URL

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

social_auth_gsis-0.5.3.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

social_auth_gsis-0.5.3-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file social_auth_gsis-0.5.3.tar.gz.

File metadata

  • Download URL: social_auth_gsis-0.5.3.tar.gz
  • Upload date:
  • Size: 3.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.3 Darwin/23.4.0

File hashes

Hashes for social_auth_gsis-0.5.3.tar.gz
Algorithm Hash digest
SHA256 2d95d6210554e3e134281e613c29b64cc8fe7f7090c2eac57966a26001e58541
MD5 f39d1200fbbd422bf0e6b884c188a6a0
BLAKE2b-256 bb0c1cdc4b1259d53e61f72a2f937e6e1917a6085d4a0ccc082ef77c1bc11818

See more details on using hashes here.

File details

Details for the file social_auth_gsis-0.5.3-py3-none-any.whl.

File metadata

File hashes

Hashes for social_auth_gsis-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 1ca637b80c1ef4be9117274c15b22c5e0e4e983317b9c485181e8b79dc089c01
MD5 786dfb4241fc782ee8fd1d92504eae92
BLAKE2b-256 1ada5637fd3d497e4027af130fa4022e1baa061084eefff267de8c274c2a4c1b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page