You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
There are a bunch of resources the provisioning system can deploy which require some kind of account:
edX (python/django)
KA-Lite, if using their LMS instead of the videos-only version (python/django)
Roundcube/webmail (php)
Learning Locker LRS (php)
Swagportal (php)
For initial deployment edX and, if possible, webmail are the only ones we need to care about.
...but something that can be easily integrated with other services would be ideal.
_What needs to be done_
Determine the best way to set up authentication with a common set of users for a broad set of applications all running on one machine.
I think we'll find that most single-signon solutions are overkill for us. They're designed to share authentication between systems, but we're only talking about services all running on the same machine, so a simpler, more light-weight solution (important since we need our stuff to work on low-end devices like the Cubietruck) should work for us.
Write ansible plays to implement it.
Make any modifications needed to the configuration of edX, etc to use it (these must also be automated, of course)
_One option for how to proceed_
In the usernamenumber/accounts branch, I've been experimenting with a role that implements a system I call Handoff. Handoff works like this:
Install and configure incron, a Linux service that monitors activity on a directory and runs a script when a file in it is added or changed.
Configure incron to monitor a directory that is expected to contain json files, with each file representing a user account.
In the future, files in other directories could be used to represent other things, not just users.
When a file is added, modified, or removed, incron runs this script, which adds, modifies, or removes the corresponding account in the local userbase.
The monitor script can be extended to also create/modify/delete users in whatever databases our apps use.
...but for anything that can authenticate against the OS userbase via PAM, it should Just Work!
Result: local accounts are managed by a form, which stores its data as json files in the monitored directory. Changes are the immediately synced to the resources used by whatever apps we care about.
To be clear, Handoff is about account management, not authentication. It updates the database(s) used by the app(s), which do authentication exactly as they normally would with no extra configuration.
...that said, I am still unsure whether this approach is brilliant, or a horrible kludge of which I should be ashamed. :P If you think the latter, I'm open to alternatives.
As a proof-of-concept I wrote a simple django app, which drops the JSON file into a directory monitored by Handoff. It also creates a Django account that can be shared by other Django apps, but in the future, this would be done by a separate script run by Handoff.
To try it out, do the following:
Clone this repo, but use the usernamenumber/accounts branch:
_Background_
_What needs to be done_
_One option for how to proceed_
In the
usernamenumber/accounts
branch, I've been experimenting with a role that implements a system I call Handoff. Handoff works like this:Result: local accounts are managed by a form, which stores its data as json files in the monitored directory. Changes are the immediately synced to the resources used by whatever apps we care about.
To be clear, Handoff is about account management, not authentication. It updates the database(s) used by the app(s), which do authentication exactly as they normally would with no extra configuration.
...that said, I am still unsure whether this approach is brilliant, or a horrible kludge of which I should be ashamed. :P If you think the latter, I'm open to alternatives.
As a proof-of-concept I wrote a simple django app, which drops the JSON file into a directory monitored by Handoff. It also creates a Django account that can be shared by other Django apps, but in the future, this would be done by a separate script run by Handoff.
To try it out, do the following:
usernamenumber/accounts
branch:git clone -b usernamenumber/accounts https://github.com/tunapanda/provision
cd provision
cp localconfig.yml.defaults localconfig.yml
localconfig.yml
and setprofile
totest_handoff
vagrant up # This will take several minutes to complete
vagrant ssh
sudo -i # I haven't set up all the filesystem perms, so just be root
cd /usr/local/tunapanda/provision/vm_data/django
pip install -r requirements.txt
./manage.py migrate
./manage.py 0.0.0.0:8000
http://IP.OF.THE.VM:8000
in your browserThe text was updated successfully, but these errors were encountered: