From d4e2b8e7b59539dc28e6e2ccc0b14f52d7b71c58 Mon Sep 17 00:00:00 2001 From: lpm0073 Date: Thu, 6 Oct 2022 15:53:54 -0500 Subject: [PATCH] convert wp_oauth to base class --- README.rst | 4 + doc/lms.log | 371 +++++------------- tests/data/wp-oauth-redirect-mismatch.json | 5 + wp_oauth_backend/base_oauth.py | 423 --------------------- wp_oauth_backend/stepwise_oauth.py | 2 +- wp_oauth_backend/wp_oauth.py | 8 +- 6 files changed, 114 insertions(+), 699 deletions(-) create mode 100644 tests/data/wp-oauth-redirect-mismatch.json delete mode 100644 wp_oauth_backend/base_oauth.py diff --git a/README.rst b/README.rst index f08a7df..43aba32 100644 --- a/README.rst +++ b/README.rst @@ -86,3 +86,7 @@ in https://stepwisemath.ai/, configured as follows: :width: 100% :alt: WP Oauth configuration page + +.. include:: doc/lms.log + :log: + \ No newline at end of file diff --git a/doc/lms.log b/doc/lms.log index 665953a..efb7898 100644 --- a/doc/lms.log +++ b/doc/lms.log @@ -1,79 +1,12 @@ -[uwsgi-static] added mapping for /static => /openedx/staticfiles/ -[uwsgi-static] added mapping for /media => /openedx/media/ -*** Starting uWSGI 2.0.20 (64bit) on [Thu Oct 6 17:10:24 2022] *** -compiled with version: 9.4.0 on 06 October 2022 16:36:30 -os: Linux-5.4.209-116.363.amzn2.x86_64 #1 SMP Wed Aug 10 21:19:18 UTC 2022 -nodename: lms-56998b7849-59cll -machine: x86_64 -clock source: unix -detected number of CPU cores: 2 -current working directory: /openedx/edx-platform -detected binary path: /openedx/venv/bin/uwsgi -!!! no internal routing support, rebuild with pcre support !!! -*** WARNING: you are running uWSGI without its master process manager *** -your memory page size is 4096 bytes -detected max file descriptor number: 1048576 -building mime-types dictionary from file /etc/mime.types...567 entry found -lock engine: pthread robust mutexes -thunder lock: enabled -uWSGI http bound on 0.0.0.0:8000 fd 4 -spawned uWSGI http 1 (pid: 8) -uwsgi socket 0 bound to TCP address 127.0.0.1:43683 (port auto-assigned) fd 3 -Python version: 3.8.12 (default, Oct 6 2022, 16:25:43) [GCC 9.4.0] -Python main interpreter initialized at 0x55e50291d070 -python threads support enabled -your server socket listen backlog is limited to 100 connections -your mercy for graceful operations on workers is 60 seconds -mapped 154032 bytes (150 KB) for 2 cores -*** Operational MODE: preforking *** -2022-10-06 17:10:38,886 INFO 7 [stepwise_plugin.apps] [user None] [ip None] apps.py:45 - stepwise_plugin is ready. -WSGI app 0 (mountpoint='') ready in 16 seconds on interpreter 0x55e50291d070 pid: 7 (default app) -spawned uWSGI worker 1 (pid: 7, cores: 1) -spawned uWSGI worker 2 (pid: 19, cores: 1) -2022-10-06 17:10:40,996 INFO 7 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/", "context": {"user_id": null, "path": "/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:40.994408+00:00", "event_type": "/", "event_source": "server", "page": null} -2022-10-06 17:10:42,099 WARNING 7 [openedx.core.djangoapps.catalog.utils] [user None] [ip 192.168.5.143] utils.py:134 - Failed to get program UUIDs from the cache for site web.stepwisemath.ai. -[pid: 7|app: 0|req: 1/1] 192.168.4.4 () {66 vars in 1707 bytes} [Thu Oct 6 17:10:40 2022] GET / => generated 24182 bytes in 2790 msecs (HTTP/1.1 200) 6 headers in 340 bytes (1 switches on core 0) -[pid: 19|app: -1|req: -1/2] 192.168.4.4 () {66 vars in 1702 bytes} [Thu Oct 6 17:10:43 2022] GET /static/js/i18n/en/djangojs.705ead69114e.js => generated 3281 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/3] 192.168.4.4 () {66 vars in 1700 bytes} [Thu Oct 6 17:10:43 2022] GET /static/js/ie11_find_array.bd1c6dc7a133.js => generated 1685 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/4] 192.168.4.4 () {66 vars in 1758 bytes} [Thu Oct 6 17:10:43 2022] GET /static/stepwise-edx-theme/css/lms-style-vendor.68e48093f5dd.css => generated 36962 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 112 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/5] 192.168.4.4 () {66 vars in 1748 bytes} [Thu Oct 6 17:10:43 2022] GET /static/stepwise-edx-theme/css/lms-main-v1.25b10a7d0738.css => generated 978210 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 113 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/6] 192.168.4.4 () {66 vars in 1700 bytes} [Thu Oct 6 17:10:43 2022] GET /static/js/lms-main_vendor.3c3c9a2604d6.js => generated 585680 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/7] 192.168.4.4 () {66 vars in 1700 bytes} [Thu Oct 6 17:10:43 2022] GET /static/js/lms-application.98d9a8549a03.js => generated 514731 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/8] 192.168.4.4 () {66 vars in 1736 bytes} [Thu Oct 6 17:10:43 2022] GET /static/bundles/commons.8c2395c2d982f7b9fe50.98e30a96357e.js => generated 410629 bytes in 1 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/9] 192.168.4.4 () {66 vars in 1706 bytes} [Thu Oct 6 17:10:43 2022] GET /static/lms/js/require-config.38226099c6ad.js => generated 9017 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/10] 192.168.4.4 () {66 vars in 1746 bytes} [Thu Oct 6 17:10:43 2022] GET /static/stepwise-edx-theme/css/rover/main.d41d8cd98f00.css => generated 0 bytes in 0 msecs (HTTP/1.1 200) 3 headers in 108 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/11] 192.168.4.4 () {66 vars in 1704 bytes} [Thu Oct 6 17:10:45 2022] GET /static/js/vendor/noreferrer.aa62a3e70ffa.js => generated 1236 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/12] 192.168.4.4 () {66 vars in 1702 bytes} [Thu Oct 6 17:10:45 2022] GET /static/js/utils/navigation.08930e16ab3d.js => generated 4438 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/13] 192.168.4.4 () {66 vars in 1695 bytes} [Thu Oct 6 17:10:45 2022] GET /static/js/header/header.309a1243e175.js => generated 7848 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/14] 192.168.4.4 () {66 vars in 1715 bytes} [Thu Oct 6 17:10:45 2022] GET /static/js/src/jquery_extend_patch.54dddef28d15.js => generated 2812 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: 0|req: 2/15] 192.168.4.4 () {64 vars in 1790 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:Querium_University+WARN102+Sample2+type@asset+block@images_course_image.jpg => generated 292992 bytes in 92 msecs (HTTP/1.1 200) 6 headers in 175 bytes (1 switches on core 0) -[pid: 7|app: 0|req: 3/16] 192.168.4.4 () {64 vars in 1791 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:Querium_University+WARN102+Sample1+type@asset+block@images_course_image.jpg => generated 292992 bytes in 79 msecs (HTTP/1.1 200) 6 headers in 175 bytes (1 switches on core 0) -[pid: 7|app: 0|req: 4/17] 192.168.4.4 () {64 vars in 1809 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:Querium_University+EISD_CL_Phase1+Fall_2022+type@asset+block@images_course_image.jpg => generated 0 bytes in 37 msecs (HTTP/1.1 404) 3 headers in 99 bytes (1 switches on core 0) -[pid: 7|app: 0|req: 5/18] 192.168.4.4 () {66 vars in 1838 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:stepwisemath+DEMO101+revd+type@asset+block@college_algebra_bookcard.png => generated 0 bytes in 65 msecs (HTTP/1.1 304) 2 headers in 62 bytes (0 switches on core 0) -[pid: 7|app: 0|req: 6/19] 192.168.4.4 () {66 vars in 1830 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:stepwisemath+DEMO101+reve+type@asset+block@precalculus_bookcard.png => generated 0 bytes in 57 msecs (HTTP/1.1 304) 2 headers in 62 bytes (0 switches on core 0) -2022-10-06 17:10:45,802 INFO 7 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/stepwise/api/v1/configuration/prod", "context": {"user_id": null, "path": "/stepwise/api/v1/configuration/prod", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:45.801743+00:00", "event_type": "/stepwise/api/v1/configuration/prod", "event_source": "server", "page": null} -[pid: 7|app: 0|req: 7/20] 192.168.4.4 () {68 vars in 1750 bytes} [Thu Oct 6 17:10:45 2022] GET /stepwise/api/v1/configuration/prod => generated 167 bytes in 54 msecs (HTTP/1.1 200) 6 headers in 189 bytes (1 switches on core 0) -[pid: 7|app: -1|req: -1/21] 192.168.4.4 () {68 vars in 1849 bytes} [Thu Oct 6 17:10:45 2022] GET /static/fonts/vendor/fontawesome-webfont.e6cf7c6ec7c2.woff2?v=4.6.3 => generated 71896 bytes in 1 msecs via sendfile() (HTTP/1.1 200) 3 headers in 114 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/22] 192.168.4.4 () {64 vars in 1654 bytes} [Thu Oct 6 17:10:45 2022] GET /static/js/dateutil_factory.a28baef97506.js?raw => generated 431182 bytes in 8 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -/openedx/venv/lib/python3.8/site-packages/pymongo/topology.py:164: UserWarning: MongoClient opened before fork. Create MongoClient only after forking. See PyMongo's documentation for details: https://pymongo.readthedocs.io/en/stable/faq.html#is-pymongo-fork-safe - warnings.warn( -[pid: 19|app: 0|req: 1/23] 192.168.4.4 () {64 vars in 1793 bytes} [Thu Oct 6 17:10:45 2022] GET /asset-v1:Querium_University+WARN102+fred_test+type@asset+block@images_course_image.jpg => generated 292992 bytes in 597 msecs (HTTP/1.1 200) 6 headers in 175 bytes (1 switches on core 0) -[pid: 7|app: 0|req: 8/24] 192.168.4.4 () {68 vars in 1785 bytes} [Thu Oct 6 17:10:47 2022] GET /login?next=%2F => generated 36862 bytes in 151 msecs (HTTP/1.1 200) 9 headers in 916 bytes (1 switches on core 0) -[pid: 19|app: -1|req: -1/25] 192.168.4.4 () {66 vars in 1714 bytes} [Thu Oct 6 17:10:48 2022] GET /static/js/lms-base-vendor.188b06b0a06d.js => generated 327113 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/26] 192.168.4.4 () {66 vars in 1724 bytes} [Thu Oct 6 17:10:48 2022] GET /static/js/lms-base-application.8c893365eb2c.js => generated 13719 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 126 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/27] 192.168.4.4 () {66 vars in 1763 bytes} [Thu Oct 6 17:10:49 2022] GET /static/js/student_account/logistration_factory.5cfe73759a4f.js?raw => generated 123632 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 127 bytes (0 switches on core 0) -2022-10-06 17:10:49,351 INFO 7 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/stepwise/api/v1/configuration/prod", "context": {"user_id": null, "path": "/stepwise/api/v1/configuration/prod", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/login?next=%2F", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:49.350992+00:00", "event_type": "/stepwise/api/v1/configuration/prod", "event_source": "server", "page": null} -[pid: 7|app: 0|req: 9/28] 192.168.4.4 () {68 vars in 1764 bytes} [Thu Oct 6 17:10:49 2022] GET /stepwise/api/v1/configuration/prod => generated 167 bytes in 34 msecs (HTTP/1.1 200) 6 headers in 189 bytes (1 switches on core 0) -[pid: 19|app: -1|req: -1/29] 192.168.4.4 () {66 vars in 1698 bytes} [Thu Oct 6 17:10:49 2022] GET /static/js/vendor/jquery.cookie.js => generated 1941 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -2022-10-06 17:10:51,094 INFO 7 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/auth/login/stepwisemath-oauth/", "context": {"user_id": null, "path": "/auth/login/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/login?next=%2F", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {\"auth_entry\": [\"login\"], \"next\": [\"/\"]}, \"POST\": {}}", "time": "2022-10-06T17:10:51.094474+00:00", "event_type": "/auth/login/stepwisemath-oauth/", "event_source": "server", "page": null} -2022-10-06 17:10:51,105 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:232 - AUTHORIZATION_URL: https://stepwisemath.ai/oauth/authorize -[pid: 7|app: 0|req: 10/30] 192.168.4.4 () {68 vars in 1883 bytes} [Thu Oct 6 17:10:51 2022] GET /auth/login/stepwisemath-oauth/?auth_entry=login&next=%2F => generated 0 bytes in 37 msecs (HTTP/1.1 302) 9 headers in 922 bytes (1 switches on core 0) -2022-10-06 17:10:53,261 INFO 19 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/auth/complete/stepwisemath-oauth/", "context": {"user_id": null, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {\"redirect_state\": [\"V1oalDl6qdC8c8JiC7PLWhf1BMPNEXGo\"], \"code\": [\"51kd3gnf8xgofxpsaf6k1pxj60vjmoizvbwkbjhs\"], \"state\": [\"V1oalDl6qdC8c8JiC7PLWhf1BMPNEXGo\"], \"iframe\": [\"break\"]}, \"POST\": {}}", "time": "2022-10-06T17:10:53.260697+00:00", "event_type": "/auth/complete/stepwisemath-oauth/", "event_source": "server", "page": null} -2022-10-06 17:10:53,899 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:239 - ACCESS_TOKEN_URL: https://stepwisemath.ai/oauth/token -2022-10-06 17:10:55,213 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:246 - USER_QUERY: https://stepwisemath.ai/oauth/me -2022-10-06 17:10:55,214 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:378 - user_data() url: https://stepwisemath.ai/oauth/me?access_token=bftc1ostvp3fucj9sxzkdgonnhcoi9uuqq2da93m -2022-10-06 17:10:57,033 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:383 - user_data() response: { - "ID": "6", +2022-10-06 20:17:08,832 INFO 19 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/auth/login/stepwisemath-oauth/", "context": {"user_id": null, "path": "/auth/login/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/login", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {\"auth_entry\": [\"login\"], \"next\": [\"/dashboard\"]}, \"POST\": {}}", "time": "2022-10-06T20:17:08.832684+00:00", "event_type": "/auth/login/stepwisemath-oauth/", "event_source": "server", "page": null} +2022-10-06 20:17:09,230 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:216 - AUTHORIZATION_URL: https://stepwisemath.ai/oauth/authorize +[pid: 19|app: 0|req: 2/19] 192.168.4.4 () {68 vars in 1889 bytes} [Thu Oct 6 20:17:08 2022] GET /auth/login/stepwisemath-oauth/?auth_entry=login&next=%2Fdashboard => generated 0 bytes in 430 msecs (HTTP/1.1 302) 9 headers in 922 bytes (1 switches on core 0) +2022-10-06 20:17:38,485 INFO 7 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/auth/complete/stepwisemath-oauth/", "context": {"user_id": null, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {\"redirect_state\": [\"pdbIKIcEbhjVr3Kon5VXUWWiy5kuX921\"], \"code\": [\"q0antmap4qfamd6pe24jh75pdprahpdiyitmut0o\"], \"state\": [\"pdbIKIcEbhjVr3Kon5VXUWWiy5kuX921\"], \"iframe\": [\"break\"]}, \"POST\": {}}", "time": "2022-10-06T20:17:38.484675+00:00", "event_type": "/auth/complete/stepwisemath-oauth/", "event_source": "server", "page": null} +2022-10-06 20:17:38,496 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:223 - ACCESS_TOKEN_URL: https://stepwisemath.ai/oauth/token +2022-10-06 20:17:40,197 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:230 - USER_QUERY: https://stepwisemath.ai/oauth/me +2022-10-06 20:17:40,197 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:363 - user_data() url: https://stepwisemath.ai/oauth/me?access_token=jx2zql9fw2jx9s7tayik4ybfjrmuhb7m5csb1mtl +2022-10-06 20:17:41,965 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:368 - user_data() response: { + "ID": "7", "capabilities": { "access_white_label_branding": true, "activate_plugins": true, @@ -160,18 +93,18 @@ spawned uWSGI worker 2 (pid: 19, cores: 1) "wf2fa_manage_settings": true, "wpseo_manage_options": true }, - "display_name": "Lawrence McDaniel", - "user_email": "lpm0073@gmail.com", - "user_login": "mcdaniel", - "user_nicename": "mcdaniel", - "user_registered": "2022-10-04 00:46:37", + "display_name": "Test McBugster", + "user_email": "test@stepwisemath.ai", + "user_login": "testaccount", + "user_nicename": "testaccount", + "user_registered": "2022-10-06 19:57:56", "user_roles": [ "administrator" ], "user_status": "0" } -2022-10-06 17:10:57,039 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:286 - get_user_details() begin with response: { - "ID": "6", +2022-10-06 20:17:41,966 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:269 - get_user_details() received wp-oauth user data response json dict: { + "ID": "7", "capabilities": { "access_white_label_branding": true, "activate_plugins": true, @@ -258,227 +191,123 @@ spawned uWSGI worker 2 (pid: 19, cores: 1) "wf2fa_manage_settings": true, "wpseo_manage_options": true }, - "display_name": "Lawrence McDaniel", - "user_email": "lpm0073@gmail.com", - "user_login": "mcdaniel", - "user_nicename": "mcdaniel", - "user_registered": "2022-10-04 00:46:37", + "display_name": "Test McBugster", + "user_email": "test@stepwisemath.ai", + "user_login": "testaccount", + "user_nicename": "testaccount", + "user_registered": "2022-10-06 19:57:56", "user_roles": [ "administrator" ], "user_status": "0" } -2022-10-06 17:10:57,040 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:328 - get_user_details() - start. response: { - "ID": "6", - "capabilities": { - "access_white_label_branding": true, - "activate_plugins": true, - "administrator": true, - "copy_posts": true, - "create_roles": true, - "create_users": true, - "delete_others_pages": true, - "delete_others_posts": true, - "delete_pages": true, - "delete_plugins": true, - "delete_posts": true, - "delete_private_pages": true, - "delete_private_posts": true, - "delete_published_pages": true, - "delete_published_posts": true, - "delete_roles": true, - "delete_themes": true, - "delete_users": true, - "edit_dashboard": true, - "edit_files": true, - "edit_others_pages": true, - "edit_others_posts": true, - "edit_pages": true, - "edit_plugins": true, - "edit_posts": true, - "edit_private_pages": true, - "edit_private_posts": true, - "edit_published_pages": true, - "edit_published_posts": true, - "edit_roles": true, - "edit_theme_options": true, - "edit_themes": true, - "edit_users": true, - "export": true, - "import": true, - "install_plugins": true, - "install_themes": true, - "level_0": true, - "level_1": true, - "level_10": true, - "level_2": true, - "level_3": true, - "level_4": true, - "level_5": true, - "level_6": true, - "level_7": true, - "level_8": true, - "level_9": true, - "list_roles": true, - "list_users": true, - "manage_categories": true, - "manage_links": true, - "manage_options": true, - "moderate_comments": true, - "promote_users": true, - "publish_pages": true, - "publish_posts": true, - "read": true, - "read_private_pages": true, - "read_private_posts": true, - "remove_users": true, - "restrict_content": true, - "rocket_manage_options": true, - "rocket_preload_cache": true, - "rocket_purge_cache": true, - "rocket_purge_cloudflare_cache": true, - "rocket_purge_opcache": true, - "rocket_purge_posts": true, - "rocket_purge_sucuri_cache": true, - "rocket_purge_terms": true, - "rocket_purge_users": true, - "rocket_regenerate_critical_css": true, - "rocket_remove_unused_css": true, - "switch_themes": true, - "unfiltered_html": true, - "unfiltered_upload": true, - "update_core": true, - "update_plugins": true, - "update_themes": true, - "upload_files": true, - "wf2fa_activate_2fa_others": true, - "wf2fa_activate_2fa_self": true, - "wf2fa_manage_settings": true, - "wpseo_manage_options": true - }, - "display_name": "Lawrence McDaniel", - "user_email": "lpm0073@gmail.com", - "user_login": "mcdaniel", - "user_nicename": "mcdaniel", - "user_registered": "2022-10-04 00:46:37", - "user_roles": [ - "administrator" - ], - "user_status": "0" -} -2022-10-06 17:10:57,041 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:257 - user_details.setter: new value set { - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, +2022-10-06 20:17:41,966 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:317 - get_user_details() processing response object +2022-10-06 20:17:41,966 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:241 - user_details.setter: new value set { + "date_joined": "2022-10-06 19:57:56", + "email": "test@stepwisemath.ai", + "first_name": "Test", + "fullname": "Test McBugster", + "id": 7, "is_staff": true, "is_superuser": true, - "last_name": "McDaniel", + "last_name": "McBugster", "refresh_token": "", "scope": "", "token_type": "", "user_status": "0", - "username": "mcdaniel" + "username": "testaccount" } -2022-10-06 17:10:57,041 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:360 - get_user_details() - finish. user_details: { - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, +2022-10-06 20:17:41,967 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:345 - get_user_details() returning: { + "date_joined": "2022-10-06 19:57:56", + "email": "test@stepwisemath.ai", + "first_name": "Test", + "fullname": "Test McBugster", + "id": 7, "is_staff": true, "is_superuser": true, - "last_name": "McDaniel", + "last_name": "McBugster", "refresh_token": "", "scope": "", "token_type": "", "user_status": "0", - "username": "mcdaniel" + "username": "testaccount" } -2022-10-06 17:10:57,041 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:392 - user_data() local variable user_details: { - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, - "is_staff": true, - "is_superuser": true, - "last_name": "McDaniel", - "refresh_token": "", - "scope": "", - "token_type": "", - "user_status": "0", - "username": "mcdaniel" -} -2022-10-06 17:10:57,041 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:398 - user_data() class property value of self.user_details: { - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, - "is_staff": true, - "is_superuser": true, - "last_name": "McDaniel", - "refresh_token": "", - "scope": "", - "token_type": "", - "user_status": "0", - "username": "mcdaniel" -} -2022-10-06 17:10:57,046 INFO 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:286 - get_user_details() begin with response: { - "access_token": "bftc1ostvp3fucj9sxzkdgonnhcoi9uuqq2da93m", - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", +2022-10-06 20:17:41,972 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:269 - get_user_details() received extended get_user_details() return dict: { + "access_token": "jx2zql9fw2jx9s7tayik4ybfjrmuhb7m5csb1mtl", + "date_joined": "2022-10-06 19:57:56", + "email": "test@stepwisemath.ai", "expires_in": 3600, - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, + "first_name": "Test", + "fullname": "Test McBugster", + "id": 7, "is_staff": true, "is_superuser": true, - "last_name": "McDaniel", + "last_name": "McBugster", "refresh_token": "", "scope": "", "token_type": "", "user_status": "0", - "username": "mcdaniel" + "username": "testaccount" } -2022-10-06 17:10:57,046 WARNING 19 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.5.143] wp_oauth.py:316 - get_user_details() - response object of get_user_details() return dict is not a valid wp-oauth object. Cannot continue. { - "access_token": "bftc1ostvp3fucj9sxzkdgonnhcoi9uuqq2da93m", - "date_joined": "2022-10-04 00:46:37", - "email": "lpm0073@gmail.com", +2022-10-06 20:17:41,973 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:241 - user_details.setter: new value set { + "access_token": "jx2zql9fw2jx9s7tayik4ybfjrmuhb7m5csb1mtl", + "date_joined": "2022-10-06 19:57:56", + "email": "test@stepwisemath.ai", "expires_in": 3600, - "first_name": "Lawrence", - "fullname": "Lawrence McDaniel", - "id": 6, + "first_name": "Test", + "fullname": "Test McBugster", + "id": 7, "is_staff": true, "is_superuser": true, - "last_name": "McDaniel", + "last_name": "McBugster", "refresh_token": "", "scope": "", "token_type": "", "user_status": "0", - "username": "mcdaniel" + "username": "testaccount" } -/openedx/venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py:1416: RuntimeWarning: DateTimeField User.date_joined received a naive datetime (2022-10-04 00:46:37) while time zone support is active. +2022-10-06 20:17:41,973 INFO 7 [wp_oauth_backend.wp_oauth] [user None] [ip 192.168.6.26] wp_oauth.py:290 - get_user_details() returning extended get_user_details() return dict: { + "access_token": "jx2zql9fw2jx9s7tayik4ybfjrmuhb7m5csb1mtl", + "date_joined": "2022-10-06 19:57:56", + "email": "test@stepwisemath.ai", + "expires_in": 3600, + "first_name": "Test", + "fullname": "Test McBugster", + "id": 7, + "is_staff": true, + "is_superuser": true, + "last_name": "McBugster", + "refresh_token": "", + "scope": "", + "token_type": "", + "user_status": "0", + "username": "testaccount" +} +[pid: 7|app: 0|req: 2/20] 192.168.4.4 () {70 vars in 2136 bytes} [Thu Oct 6 20:17:38 2022] GET /auth/complete/stepwisemath-oauth/?redirect_state=pdbIKIcEbhjVr3Kon5VXUWWiy5kuX921&code=q0antmap4qfamd6pe24jh75pdprahpdiyitmut0o&state=pdbIKIcEbhjVr3Kon5VXUWWiy5kuX921&iframe=break => generated 0 bytes in 3549 msecs (HTTP/1.1 302) 9 headers in 612 bytes (1 switches on core 0) +2022-10-06 20:17:42,211 INFO 19 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/register", "context": {"user_id": null, "path": "/register", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T20:17:42.211436+00:00", "event_type": "/register", "event_source": "server", "page": null} +[pid: 19|app: 0|req: 3/21] 192.168.4.4 () {70 vars in 1796 bytes} [Thu Oct 6 20:17:42 2022] GET /register => generated 37606 bytes in 177 msecs (HTTP/1.1 200) 8 headers in 600 bytes (1 switches on core 0) +2022-10-06 20:17:42,527 INFO 7 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/stepwise/api/v1/configuration/prod", "context": {"user_id": null, "path": "/stepwise/api/v1/configuration/prod", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T20:17:42.527217+00:00", "event_type": "/stepwise/api/v1/configuration/prod", "event_source": "server", "page": null} +[pid: 7|app: 0|req: 3/22] 192.168.4.4 () {68 vars in 1755 bytes} [Thu Oct 6 20:17:42 2022] GET /stepwise/api/v1/configuration/prod => generated 167 bytes in 41 msecs (HTTP/1.1 200) 6 headers in 189 bytes (1 switches on core 0) +2022-10-06 20:17:42,617 INFO 19 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/api/user/v2/account/registration/", "context": {"user_id": null, "path": "/api/user/v2/account/registration/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {\"next\": [\"/dashboard\"], \"email\": [\"test@stepwisemath.ai\"], \"name\": [\"Test McBugster\"], \"username\": [\"testaccount\"], \"password\": \"********\", \"level_of_education\": [\"\"], \"gender\": [\"\"], \"year_of_birth\": [\"\"], \"mailing_address\": [\"\"], \"goals\": [\"\"], \"social_auth_provider\": [\"Stepwise\"], \"terms_of_service\": [\"true\"]}}", "time": "2022-10-06T20:17:42.616767+00:00", "event_type": "/api/user/v2/account/registration/", "event_source": "server", "page": null} +2022-10-06 20:17:42,620 INFO 7 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/api/user/v1/validation/registration", "context": {"user_id": null, "path": "/api/user/v1/validation/registration", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {\"name\": [\"Test McBugster\"], \"username\": [\"testaccount\"], \"password\": \"********\", \"email\": [\"test@stepwisemath.ai\"], \"terms_of_service\": [\"false\"]}}", "time": "2022-10-06T20:17:42.619453+00:00", "event_type": "/api/user/v1/validation/registration", "event_source": "server", "page": null} +[pid: 7|app: 0|req: 4/23] 192.168.4.4 () {74 vars in 1928 bytes} [Thu Oct 6 20:17:42 2022] POST /api/user/v1/validation/registration => generated 205 bytes in 85 msecs (HTTP/1.1 200) 8 headers in 282 bytes (1 switches on core 0) +2022-10-06 20:17:42,719 INFO 7 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/api/user/v1/validation/registration", "context": {"user_id": null, "path": "/api/user/v1/validation/registration", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {\"name\": [\"Test McBugster\"], \"username\": [\"testaccount\"], \"password\": \"********\", \"email\": [\"test@stepwisemath.ai\"], \"terms_of_service\": [\"false\"]}}", "time": "2022-10-06T20:17:42.719504+00:00", "event_type": "/api/user/v1/validation/registration", "event_source": "server", "page": null} +[pid: 7|app: 0|req: 5/24] 192.168.4.4 () {74 vars in 1928 bytes} [Thu Oct 6 20:17:42 2022] POST /api/user/v1/validation/registration => generated 205 bytes in 102 msecs (HTTP/1.1 200) 8 headers in 282 bytes (1 switches on core 0) +2022-10-06 20:17:42,816 INFO 7 [tracking] [user None] [ip 192.168.6.26] logger.py:41 - {"name": "/api/user/v1/validation/registration", "context": {"user_id": null, "path": "/api/user/v1/validation/registration", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {\"name\": [\"Test McBugster\"], \"username\": [\"testaccount\"], \"password\": \"********\", \"email\": [\"test@stepwisemath.ai\"], \"terms_of_service\": [\"false\"]}}", "time": "2022-10-06T20:17:42.816042+00:00", "event_type": "/api/user/v1/validation/registration", "event_source": "server", "page": null} +[pid: 7|app: 0|req: 6/25] 192.168.4.4 () {74 vars in 1928 bytes} [Thu Oct 6 20:17:42 2022] POST /api/user/v1/validation/registration => generated 205 bytes in 77 msecs (HTTP/1.1 200) 8 headers in 282 bytes (1 switches on core 0) +2022-10-06 20:17:43,160 INFO 19 [audit] [user 53] [ip 192.168.6.26] models.py:2753 - Login success - user.id: 53 +2022-10-06 20:17:43,221 INFO 19 [tracking] [user 53] [ip 192.168.6.26] logger.py:41 - {"name": "edx.user.settings.changed", "context": {"user_id": null, "path": "/api/user/v2/account/registration/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": {"old": null, "new": "en", "truncated": [], "setting": "pref-lang", "user_id": 53, "table": "user_api_userpreference"}, "time": "2022-10-06T20:17:43.220899+00:00", "event_type": "edx.user.settings.changed", "event_source": "server", "page": null} +2022-10-06 20:17:43,239 INFO 19 [tracking] [user 53] [ip 192.168.6.26] logger.py:41 - {"name": "edx.user.settings.changed", "context": {"user_id": null, "path": "/api/user/v2/account/registration/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "a3f4ac2a5bf97f717f5745984059891b", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": {"old": false, "new": true, "truncated": [], "setting": "is_active", "user_id": 53, "table": "auth_user"}, "time": "2022-10-06T20:17:43.238965+00:00", "event_type": "edx.user.settings.changed", "event_source": "server", "page": null} +/openedx/venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py:1416: RuntimeWarning: DateTimeField Registration.activation_timestamp received a naive datetime (2022-10-06 20:17:43.246811) while time zone support is active. warnings.warn("DateTimeField %s received a naive datetime (%s)" -2022-10-06 17:10:57,067 INFO 19 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "edx.user.settings.changed", "context": {"user_id": null, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": {"old": "2022-10-04T00:46:37+00:00", "new": "2022-10-04 00:46:37", "truncated": [], "setting": "date_joined", "user_id": 52, "table": "auth_user"}, "time": "2022-10-06T17:10:57.066609+00:00", "event_type": "edx.user.settings.changed", "event_source": "server", "page": null} -[pid: 19|app: 0|req: 2/31] 192.168.4.4 () {68 vars in 2113 bytes} [Thu Oct 6 17:10:53 2022] GET /auth/complete/stepwisemath-oauth/?redirect_state=V1oalDl6qdC8c8JiC7PLWhf1BMPNEXGo&code=51kd3gnf8xgofxpsaf6k1pxj60vjmoizvbwkbjhs&state=V1oalDl6qdC8c8JiC7PLWhf1BMPNEXGo&iframe=break => generated 0 bytes in 4017 msecs (HTTP/1.1 302) 14 headers in 3332 bytes (1 switches on core 0) -2022-10-06 17:10:57,377 INFO 7 [tracking] [user None] [ip 192.168.5.143] logger.py:41 - {"name": "/auth/complete/stepwisemath-oauth/", "context": {"user_id": null, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "", "session": "efc4e03a6eb4264dbbd70fd1bd30601f", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:57.377280+00:00", "event_type": "/auth/complete/stepwisemath-oauth/", "event_source": "server", "page": null} -2022-10-06 17:10:57,410 INFO 7 [audit] [user 52] [ip 192.168.5.143] models.py:2753 - Login success - user.id: 52 -[pid: 7|app: 0|req: 11/32] 192.168.4.4 () {68 vars in 3897 bytes} [Thu Oct 6 17:10:57 2022] GET /auth/complete/stepwisemath-oauth/? => generated 0 bytes in 83 msecs (HTTP/1.1 302) 11 headers in 936 bytes (1 switches on core 0) -2022-10-06 17:10:57,586 INFO 19 [tracking] [user 52] [ip 192.168.5.143] logger.py:41 - {"name": "/", "context": {"user_id": 52, "path": "/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "mcdaniel", "session": "e2e372be44e88efa6f77e91e67584808", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:57.586104+00:00", "event_type": "/", "event_source": "server", "page": null} -[pid: 19|app: 0|req: 3/33] 192.168.4.4 () {68 vars in 3830 bytes} [Thu Oct 6 17:10:57 2022] GET / => generated 0 bytes in 44 msecs (HTTP/1.1 302) 8 headers in 521 bytes (1 switches on core 0) -2022-10-06 17:10:57,743 INFO 7 [tracking] [user 52] [ip 192.168.5.143] logger.py:41 - {"name": "/dashboard", "context": {"user_id": 52, "path": "/dashboard", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "mcdaniel", "session": "e2e372be44e88efa6f77e91e67584808", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:57.743242+00:00", "event_type": "/dashboard", "event_source": "server", "page": null} -2022-10-06 17:10:57,795 WARNING 7 [openedx.core.djangoapps.catalog.utils] [user 52] [ip 192.168.5.143] utils.py:134 - Failed to get program UUIDs from the cache for site web.stepwisemath.ai. -2022-10-06 17:10:58,019 INFO 7 [stepwise_plugin.locale.utils] [user 52] [ip 192.168.5.143] utils.py:52 - language_from_request() found an existing language preference of en for username mcdaniel -2022-10-06 17:10:58,035 INFO 7 [stepwise_plugin.ecommerce.utils] [user 52] [ip 192.168.5.143] utils.py:256 - paywall_should_render() - Faculty user - never block!, returning False. -[pid: 7|app: 0|req: 12/34] 192.168.4.4 () {68 vars in 3848 bytes} [Thu Oct 6 17:10:57 2022] GET /dashboard => generated 20103 bytes in 341 msecs (HTTP/1.1 200) 7 headers in 500 bytes (1 switches on core 0) -[pid: 19|app: -1|req: -1/35] 192.168.4.4 () {66 vars in 3783 bytes} [Thu Oct 6 17:10:58 2022] GET /static/js/commerce/credit.e4a82bfe5f09.js => generated 1333 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/36] 192.168.4.4 () {66 vars in 3819 bytes} [Thu Oct 6 17:10:58 2022] GET /static/js/learner_dashboard/certificate_api.ea59bd620247.js => generated 620 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 124 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/37] 192.168.4.4 () {66 vars in 3771 bytes} [Thu Oct 6 17:10:58 2022] GET /static/js/dashboard.5735ee1af594.js => generated 15010 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 126 bytes (0 switches on core 0) -[pid: 19|app: -1|req: -1/38] 192.168.4.4 () {66 vars in 3865 bytes} [Thu Oct 6 17:10:58 2022] GET /static/bundles/EntitlementUnenrollmentFactory.3fc6969ae987de0a2c38.c553da8371cd.js => generated 6737 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/39] 192.168.4.4 () {66 vars in 3843 bytes} [Thu Oct 6 17:10:58 2022] GET /static/bundles/UnenrollmentFactory.de1e113a497364d5393f.c1f49727ce7e.js => generated 4374 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 125 bytes (0 switches on core 0) -[pid: 7|app: -1|req: -1/40] 192.168.4.4 () {66 vars in 3861 bytes} [Thu Oct 6 17:10:58 2022] GET /static/images/profiles/default_50.3455a6581573.png => generated 420 bytes in 0 msecs via sendfile() (HTTP/1.1 200) 3 headers in 111 bytes (0 switches on core 0) -2022-10-06 17:10:58,248 INFO 19 [tracking] [user 52] [ip 192.168.5.143] logger.py:41 - {"name": "/stepwise/api/v1/configuration/prod", "context": {"user_id": 52, "path": "/stepwise/api/v1/configuration/prod", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "mcdaniel", "session": "e2e372be44e88efa6f77e91e67584808", "ip": "192.168.5.143", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/dashboard", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T17:10:58.248121+00:00", "event_type": "/stepwise/api/v1/configuration/prod", "event_source": "server", "page": null} -[pid: 19|app: 0|req: 4/41] 192.168.4.4 () {68 vars in 3833 bytes} [Thu Oct 6 17:10:58 2022] GET /stepwise/api/v1/configuration/prod => generated 167 bytes in 62 msecs (HTTP/1.1 200) 7 headers in 349 bytes (1 switches on core 0) +2022-10-06 20:17:43,254 INFO 19 [common.djangoapps.student.models] [user 53] [ip 192.168.6.26] models.py:938 - User testaccount (test@stepwisemath.ai) account is successfully activated. +2022-10-06 20:17:43,255 INFO 19 [openedx_events.tooling] [user 53] [ip 192.168.6.26] tooling.py:160 - Responses of the Open edX Event : +[] +2022-10-06 20:17:43,261 INFO 19 [audit] [user 53] [ip 192.168.6.26] register.py:295 - Login success on new account creation - testaccount +[pid: 19|app: 0|req: 4/26] 192.168.4.4 () {74 vars in 1881 bytes} [Thu Oct 6 20:17:42 2022] POST /api/user/v2/account/registration/ => generated 79 bytes in 1145 msecs (HTTP/1.1 200) 15 headers in 3254 bytes (1 switches on core 0) +2022-10-06 20:17:44,014 INFO 7 [tracking] [user 53] [ip 192.168.6.26] logger.py:41 - {"name": "/auth/complete/stepwisemath-oauth/", "context": {"user_id": 53, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "testaccount", "session": "4b87c052d7ba72c52f84c82737834d90", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T20:17:44.014681+00:00", "event_type": "/auth/complete/stepwisemath-oauth/", "event_source": "server", "page": null} +/openedx/venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py:1416: RuntimeWarning: DateTimeField User.date_joined received a naive datetime (2022-10-06 19:57:56) while time zone support is active. + warnings.warn("DateTimeField %s received a naive datetime (%s)" +2022-10-06 20:17:44,100 INFO 7 [tracking] [user 53] [ip 192.168.6.26] logger.py:41 - {"name": "edx.user.settings.changed", "context": {"user_id": 53, "path": "/auth/complete/stepwisemath-oauth/", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "testaccount", "session": "4b87c052d7ba72c52f84c82737834d90", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": {"old": "2022-10-06T20:17:42.674048+00:00", "new": "2022-10-06 19:57:56", "truncated": [], "setting": "date_joined", "user_id": 53, "table": "auth_user"}, "time": "2022-10-06T20:17:44.100229+00:00", "event_type": "edx.user.settings.changed", "event_source": "server", "page": null} +[pid: 7|app: 0|req: 7/27] 192.168.4.4 () {66 vars in 3727 bytes} [Thu Oct 6 20:17:43 2022] GET /auth/complete/stepwisemath-oauth/? => generated 0 bytes in 150 msecs (HTTP/1.1 302) 10 headers in 721 bytes (1 switches on core 0) +2022-10-06 20:17:44,375 INFO 19 [tracking] [user 53] [ip 192.168.6.26] logger.py:41 - {"name": "/dashboard", "context": {"user_id": 53, "path": "/dashboard", "course_id": "", "org_id": "", "enterprise_uuid": ""}, "username": "testaccount", "session": "4b87c052d7ba72c52f84c82737834d90", "ip": "192.168.6.26", "agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36", "host": "web.stepwisemath.ai", "referer": "https://web.stepwisemath.ai/register", "accept_language": "en-US,en;q=0.9,es-MX;q=0.8,es-US;q=0.7,es;q=0.6", "event": "{\"GET\": {}, \"POST\": {}}", "time": "2022-10-06T20:17:44.374973+00:00", "event_type": "/dashboard", "event_source": "server", "page": null} diff --git a/tests/data/wp-oauth-redirect-mismatch.json b/tests/data/wp-oauth-redirect-mismatch.json new file mode 100644 index 0000000..4a7c5ba --- /dev/null +++ b/tests/data/wp-oauth-redirect-mismatch.json @@ -0,0 +1,5 @@ +{ + "error": "redirect_uri_mismatch", + "error_description": "The redirect URI provided is missing or does not match", + "error_uri": "http://tools.ietf.org/html/rfc6749#section-3.1.2" +} \ No newline at end of file diff --git a/wp_oauth_backend/base_oauth.py b/wp_oauth_backend/base_oauth.py deleted file mode 100644 index 90b9e3f..0000000 --- a/wp_oauth_backend/base_oauth.py +++ /dev/null @@ -1,423 +0,0 @@ -""" -written by: Lawrence McDaniel - https://lawrencemcdaniel.com - -date: oct-2022 - -usage: subclass of BaseOAuth2 Third Party Authtencation client to - handle the field mapping and data conversions between - the dict that WP Oauth returns versus the dict that Open edX - actually needs. -""" -import json -from urllib.parse import urlencode -from urllib.request import urlopen -from logging import getLogger -from social_core.backends.oauth import BaseOAuth2 -from django.contrib.auth import get_user_model - - -User = get_user_model() -logger = getLogger(__name__) - -VERBOSE_LOGGING = True - - -class WPOpenEdxOAuth2(BaseOAuth2): - """ - WP OAuth authentication backend customized for Open edX. - see https://python-social-auth.readthedocs.io/en/latest/backends/implementation.html - - Notes: - - Python Social Auth social_core and/or Open edX's third party authentication core - are finicky about how the "properties" are implemented. Anything that actually - declared as a Python class variable needs to remain a Python class variable. - DO NOT refactor these into formal Python properties as something upstream will - break your code. - - - for some reason adding an __init__() def to this class also causes something - upstream to break. If you try this then you'll get an error about a missing - positional argument, 'strategy'. - """ - - _user_details = None - - # This defines the backend name and identifies it during the auth process. - # The name is used in the URLs /login/ and /complete/. - # - # This is the string value that will appear in the LMS Django Admin - # Third Party Authentication / Provider Configuration (OAuth) - # setup page drop-down box titled, "Backend name:", just above - # the "Client ID:" and "Client Secret:" fields. - name = "wp-oauth" - - # note: no slash at the end of the base url. Python Social Auth - # might clean this up for you, but i'm not 100% certain of that. - BASE_URL = "https://set-me-please.com" - - # The default key name where the user identification field is defined, it’s - # used in the auth process when some basic user data is returned. This Id - # is stored in the UserSocialAuth.uid field and this, together with the - # UserSocialAuth.provider field, is used to uniquely identify a user association. - ID_KEY = "id" - - # Flags the backend to enforce email validation during the pipeline - # (if the corresponding pipeline social_core.pipeline.mail.mail_validation was enabled). - REQUIRES_EMAIL_VALIDATION = False - - # Some providers give nothing about the user but some basic data like the - # user Id or an email address. The default scope attribute is used to - # specify a default value for the scope argument to request those extra bits. - # - # wp-oauth supports 4 scopes: basic, email, profile, openeid. - # we want the first three of these. - # see https://wp-oauth.com/docs/how-to/adding-supported-scopes/ - DEFAULT_SCOPE = ["basic", "profile", "email"] - - # Specifying the method type required to retrieve your access token if it’s - # not the default GET request. - ACCESS_TOKEN_METHOD = "POST" - - # require redirect domain to match the original initiating domain. - SOCIAL_AUTH_SANITIZE_REDIRECTS = True - - # During the auth process some basic user data is returned by the provider - # or retrieved by the user_data() method which usually is used to call - # some API on the provider to retrieve it. This data will be stored in the - # UserSocialAuth.extra_data attribute, but to make it accessible under some - # common names on different providers, this attribute defines a list of - # tuples in the form (name, alias) where name is the key in the user data - # (which should be a dict instance) and alias is the name to store it on extra_data. - EXTRA_DATA = [ - ("id", "id"), - ("is_superuser", "is_superuser"), - ("is_staff", "is_staff"), - ("date_joined", "date_joined"), - ] - - # the value of the scope separator is user-defined. Check the - # scopes field value for your oauth client in your wordpress host. - # the wp-oauth default value for scopes is 'basic' but can be - # changed to a list. example 'basic, email, profile'. This - # list can be delimited with commas, spaces, whatever. - SCOPE_SEPARATOR = " " - - # private utility function. not part of psa. - def _urlopen(self, url): - """ - ensure that url response object is utf-8 encoded. - """ - return urlopen(url).read().decode("utf-8") - - def is_valid_dict(self, response, qc_keys) -> bool: - if not type(response) == dict: - logger.warning( - "is_valid_dict() was expecting a dict but received an object of type: {type}".format( - type=type(response) - ) - ) - return False - return all(key in response for key in qc_keys) - - def is_valid_user_details(self, response) -> bool: - """ - validate that the object passed is a json dict containing at least - the keys in qc_keys. These are the dict keys created in get_user_details() - default return object. - """ - qc_keys = [ - "id", - "date_joined", - "email", - "first_name", - "fullname", - "is_staff", - "is_superuser", - "last_name", - "username", - ] - return self.is_valid_dict(response, qc_keys) - - def is_wp_oauth_error(self, response) -> bool: - """ - validate the structure of the response object conforms to a - wp-oauth error json dict. - """ - qc_keys = ["error" "error_description"] - return self.is_valid_dict(response, qc_keys) and len(response.keys()) == 2 - - def is_wp_oauth_response(self, response) -> bool: - """ - validate the structure of the response object from wp-oauth. it's - supposed to be a dict with at least the keys included in qc_keys. - """ - qc_keys = [ - "ID", - "capabilities", - "display_name", - "user_email", - "user_login", - "user_roles", - "user_registered", - "user_status", - ] - return self.is_valid_dict(response, qc_keys) - - def is_wp_oauth_refresh_token_response(self, response) -> bool: - """ - validate that the structure of the response contains the keys of - a refresh token dict. - """ - qc_keys = ["access_token", "expires_in", "refresh_token", "scope", "token_type"] - return self.is_valid_dict(response, qc_keys) - - def is_get_user_details_extended_dict(self, response) -> bool: - """ - validate whether the structure the response is a dict that - contains a.) all keys of a get_user_details() return, plus, - b.) all keys of a wp-oauth refresh token response. - """ - return self.is_valid_user_details( - response - ) and self.is_wp_oauth_refresh_token_response(response) - - def is_valid_get_user_details_response(self, response) -> bool: - """ - True if the response object can be processed by get_user_details() - """ - return self.is_valid_user_details(response) or self.is_wp_oauth_response( - response - ) - - def get_response_type(self, response) -> str: - if type(response) != dict: - return "unknown response of type {t}".format(t=type(response)) - if self.is_wp_oauth_error(response): - return "error response json dict" - if self.is_get_user_details_extended_dict(response): - return "extended get_user_details() return dict" - if self.is_wp_oauth_refresh_token_response(response): - return "wp-oauth refresh token json dict" - if self.is_wp_oauth_response(response): - return "wp-oauth user data response json dict" - if self.is_valid_user_details(response): - return "get_user_details() return dict" - return "unrecognized response dict" - - # override Python Social Auth default end points. - # see https://wp-oauth.com/docs/general/endpoints/ - # - # Note that we're only implementing Python properties - # so that we can include logging for diagnostic purposes. - @property - def AUTHORIZATION_URL(self) -> str: - url = f"{self.BASE_URL}/oauth/authorize" - if VERBOSE_LOGGING: - logger.info("AUTHORIZATION_URL: {url}".format(url=url)) - return url - - @property - def ACCESS_TOKEN_URL(self) -> str: - url = f"{self.BASE_URL}/oauth/token" - if VERBOSE_LOGGING: - logger.info("ACCESS_TOKEN_URL: {url}".format(url=url)) - return url - - @property - def USER_QUERY(self) -> str: - url = f"{self.BASE_URL}/oauth/me" - if VERBOSE_LOGGING: - logger.info("USER_QUERY: {url}".format(url=url)) - return url - - @property - def user_details(self) -> dict: - return self._user_details - - @user_details.setter - def user_details(self, value: dict): - if self.is_valid_user_details(value): - if VERBOSE_LOGGING: - logger.info( - "user_details.setter: new value set {value}".format( - value=json.dumps(value, sort_keys=True, indent=4) - ) - ) - self._user_details = value - else: - logger.error( - "user_details.setter: tried to pass an invalid object {value}".format( - value=json.dumps(value, sort_keys=True, indent=4) - ) - ) - - # see https://python-social-auth.readthedocs.io/en/latest/backends/implementation.html - # Return user details from the Wordpress user account - def get_user_details(self, response) -> dict: - if not self.is_valid_get_user_details_response(response): - logger.error( - "get_user_details() received an invalid response object of {t}:{response} Cannot continue. Returning: {retval}".format( - t=self.get_response_type(response), - response=json.dumps(response, sort_keys=True, indent=4), - retval=json.dumps(self.user_details, sort_keys=True, indent=4), - ) - ) - # if we have cached results then we might be able to recover. - return self.user_details - - if VERBOSE_LOGGING: - logger.info( - "get_user_details() received {t}: {response}".format( - t=self.get_response_type(response), - response=json.dumps(response, sort_keys=True, indent=4), - ) - ) - # a def in the third_party_auth pipeline list calls get_user_details() after its already - # been called once. i don't know why. but, it passes the original get_user_details() dict - # enhanced with additional token-related keys. if we receive this modified dict then we - # should pass it along to the next defs in the pipeline. - # - # If most of the original keys (see dict definition below) exist in the response object - # then we can assume that this is our case. - if self.is_get_user_details_extended_dict(response): - # ------------------------------------------------------------- - # expected use case #2: an enhanced derivation of an original - # user_details dict. This is created when get_user_details() - # is called from user_data(). - # ------------------------------------------------------------- - self.user_details = response - if VERBOSE_LOGGING: - logger.info( - "get_user_details() returning {t}: {response}".format( - t=self.get_response_type(response), - response=json.dumps( - self.user_details, sort_keys=True, indent=4 - ), - ) - ) - return self.user_details - - # at this point we've ruled out the possibility of the response object - # being a derivation of a user_details dict. So, it should therefore - # conform to the structure of a wp-oauth dict. - if not self.is_wp_oauth_response(response): - logger.warning( - "get_user_details() response object of {t} is not a valid wp-oauth object: {response}. Cannot continue. returning: {retval}".format( - t=self.get_response_type(response), - response=json.dumps(response, sort_keys=True, indent=4), - retval=json.dumps(self.user_details, sort_keys=True, indent=4), - ) - ) - return self.user_details - - # ------------------------------------------------------------- - # expected use case #1: response object is a dict with all required keys. - # ------------------------------------------------------------- - if VERBOSE_LOGGING: - logger.info("get_user_details() processing response object") - - # try to parse out the first and last names - split_name = response.get("display_name", "").split() - first_name = split_name[0] if len(split_name) > 0 else "" - last_name = split_name[-1] if len(split_name) == 2 else "" - - # check for superuser / staff status - user_roles = response.get("user_roles", []) - super_user = "administrator" in user_roles - is_staff = "administrator" in user_roles - - self.user_details = { - "id": int(response.get("ID"), 0), - "username": response.get("user_login", ""), - "email": response.get("user_email", ""), - "first_name": first_name, - "last_name": last_name, - "fullname": response.get("display_name", ""), - "is_superuser": super_user, - "is_staff": is_staff, - "refresh_token": response.get("refresh_token", ""), - "scope": response.get("scope", ""), - "token_type": response.get("token_type", ""), - "date_joined": response.get("user_registered", ""), - "user_status": response.get("user_status", ""), - } - if VERBOSE_LOGGING: - logger.info( - "get_user_details() returning: {user_details}".format( - user_details=json.dumps(self.user_details, sort_keys=True, indent=4) - ) - ) - return self.user_details - - # Load user data from service url end point. Note that in the case of - # wp oauth, the response object returned by self.USER_QUERY - # is the same as the response object passed to get_user_details(). - # - # see https://python-social-auth.readthedocs.io/en/latest/backends/implementation.html - def user_data(self, access_token, *args, **kwargs) -> dict: - response = None - user_details = None - url = f"{self.USER_QUERY}?" + urlencode({"access_token": access_token}) - - if VERBOSE_LOGGING: - logger.info("user_data() url: {url}".format(url=url)) - - try: - response = json.loads(self._urlopen(url)) - if VERBOSE_LOGGING: - logger.info( - "user_data() response: {response}".format( - response=json.dumps(response, sort_keys=True, indent=4) - ) - ) - - user_details = self.get_user_details(response) - - except ValueError as e: - logger.error("user_data() {err}".format(err=e)) - return None - - if not self.is_valid_user_details(user_details): - logger.error( - "user_data() user_details return object of {t} is invalid: {user_details}".format( - t=self.get_response_type(response), - user_details=json.dumps(user_details, sort_keys=True, indent=4), - ) - ) - return self.user_details - - # add syncronization of any data fields that get missed by the built-in - # open edx third party authentication sync functionality. - try: - # this gets called just prior to account creation for - # new users, hence, we need to catch DoesNotExist - # exceptions. - user = User.objects.get(username=self.user_details["username"]) - except User.DoesNotExist: - return self.user_details - - if (user.is_superuser != self.user_details["is_superuser"]) or ( - user.is_staff != self.user_details["is_staff"] - ): - user.is_superuser = self.user_details["is_superuser"] - user.is_staff = self.user_details["is_staff"] - user.save() - logger.info( - "Updated the is_superuser/is_staff flags for user {username}".format( - username=user.username - ) - ) - - if (user.first_name != self.user_details["first_name"]) or ( - user.last_name != self.user_details["last_name"] - ): - user.first_name = self.user_details["first_name"] - user.last_name = self.user_details["last_name"] - user.save() - logger.info( - "Updated first_name/last_name for user {username}".format( - username=user.username - ) - ) - - return self.user_details diff --git a/wp_oauth_backend/stepwise_oauth.py b/wp_oauth_backend/stepwise_oauth.py index f3a822a..78de8f1 100644 --- a/wp_oauth_backend/stepwise_oauth.py +++ b/wp_oauth_backend/stepwise_oauth.py @@ -1,5 +1,5 @@ +from .wp_oauth import WPOpenEdxOAuth2 -from .base_oauth import WPOpenEdxOAuth2 class StepwiseMathWPOAuth2(WPOpenEdxOAuth2): diff --git a/wp_oauth_backend/wp_oauth.py b/wp_oauth_backend/wp_oauth.py index 14007cf..430881e 100644 --- a/wp_oauth_backend/wp_oauth.py +++ b/wp_oauth_backend/wp_oauth.py @@ -23,7 +23,7 @@ logger = getLogger(__name__) VERBOSE_LOGGING = True -class StepwiseMathWPOAuth2(BaseOAuth2): +class WPOpenEdxOAuth2(BaseOAuth2): """ WP OAuth authentication backend customized for Open edX. see https://python-social-auth.readthedocs.io/en/latest/backends/implementation.html @@ -49,11 +49,11 @@ class StepwiseMathWPOAuth2(BaseOAuth2): # Third Party Authentication / Provider Configuration (OAuth) # setup page drop-down box titled, "Backend name:", just above # the "Client ID:" and "Client Secret:" fields. - name = "stepwisemath-oauth" + name = "wp-oauth" # note: no slash at the end of the base url. Python Social Auth # might clean this up for you, but i'm not 100% certain of that. - BASE_URL = "https://stepwisemath.ai" + BASE_URL = "https://set-me-please.com" # The default key name where the user identification field is defined, it’s # used in the auth process when some basic user data is returned. This Id @@ -144,7 +144,7 @@ class StepwiseMathWPOAuth2(BaseOAuth2): wp-oauth error json dict. """ qc_keys = ["error" "error_description"] - return self.is_valid_dict(response, qc_keys) and len(response.keys()) == 2 + return self.is_valid_dict(response, qc_keys) def is_wp_oauth_response(self, response) -> bool: """