File: README.org

package info (click to toggle)
django-allauth 65.15.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 11,524 kB
  • sloc: python: 45,207; javascript: 3,335; xml: 849; makefile: 218; sh: 6
file content (99 lines) | stat: -rw-r--r-- 4,414 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
* React Single-Page Application

This directory contains an example React application demonstrating the use of
the headless functionality of django-allauth. The example consists of two parts,
a backend running allauth in =HEADLESS_ONLY= mode, and a frontend containing the
React application itself.

This example can be found up and running over at [[https://react.demo.allauth.org/][react.demo.allauth.org]]. You can
run it locally as well, as is documented below.


** Backend

The example backend Django project can be found in the =backend/= directory.  It
is running in =HEADLESS_ONLY= mode, meaning, no frontend facing functionality of
allauth is used. Hence, there are no templates or additional apps/views to be
found in this example Django project. The only points of interest of this
project are:

- The configuration of =HEADLESS_ONLY = True= over at =settings.py=.

- Configuring =HEADLESS_FRONTEND_URLS= so that allauth can construct links pointing
  to the single-page React application.

- The inclusion of =path("_allauth/", include("allauth.headless.urls"))= over at
  =urls.py=.


** Frontend

The frontend can be found in the =frontend/= directory. It is a fairly minimal
example React project created using =create-react-app=, extended with
=react-(router-)dom= for implementing routing within the single-page
application.

The sole purpose of this project is to demonstrate the technical integration of
headless allauth within a Javascript single-page application. A pretty look and
feel is not a goal, and hence, minimal effort has been spent on making the
frontend visually appealing.

Points of interest of this project:

- [[file:frontend/src/lib/allauth.js][frontend/src/lib/allauth.js]]: This is a (React independent) file offering
  wrapper methods for the various allauth endpoints.

- [[file:frontend/src/auth/AuthContext.js][frontend/src/auth/AuthContext.js]]: This file offers a React context provider
  that is able to expose the authentication state to other React components.

- [[file:frontend/src/auth/hooks.js][frontend/src/auth/hooks.js]]: Offers various hooks that use the context provider above to make
  the current user (=useUser()=), allauth configuration (=useConfig()=) and authentication state (=useAuth()=)
  easily consumable in components.

- [[file:frontend/src/auth/routing.js][frontend/src/auth/routing.js]]: When the authentication state changes, the user
  typically needs to be redirected to a different page. That logic is contained
  within this file.

- [[file:frontend/src/account/][frontend/src/account/]]: This directory contains all components related towards
  the regular account functionality (e.g. login and signup using a local
  account, as well as changing your password and email verification). This functionality corresponds
  with the functionality of the =allauth.account= Django app.

- [[file:frontend/src/socialaccount/][frontend/src/socialaccount/]]: This directory contains all components related
  towards the logging in with third-party accounts. This functionality corresponds
  with the functionality of the =allauth.socialaccount= Django app.

- [[file:frontend/src/mfa/][frontend/src/mfa/]]: This directory contains all components related towards
  Two-Factor Authentication. This functionality corresponds with the
  functionality of the =allauth.mfa= Django app.

- [[file:frontend/src/usersessions/][frontend/src/usersessions/]]: This directory contains user session management
  component. This functionality corresponds with the functionality of the
  =allauth.usersessions= Django app.

- [[file:frontend/src/Router.js][frontend/src/Router.js]]: All routing is containing within this file.


** Running

A =docker-compose.yml= file is offered using which you can easily run the
example project locally. It consists of the following services:

- =backend=: The Django backend application running =allauth.headless=.
  The backend runs on port 8000.

- =frontend=:  The frontend (React) project, running on port 3000.

- =proxy=: A proxy service (Traefik), running on port 10000, that depending on the URL
  forwards either to the backend or frontend service.

- =mail=: A dummy email (SMTP) service (MailCatcher) that you can use to test
  e.g. email verification and password reset flows.

To spin up these services, run:

#+begin_src bash
  docker-compose up
#+end_src

Then, visit the app over at http://localhost:10000.