Creating and Logging in as a new user on your local client - internetarchive/openlibrary GitHub Wiki
Typically, logging into the Open Library entails cross-authenticating with an Internet Archive account. This isn't an option on the local-host, so a few work-arounds are needed to properly reproduce certain bugs.
However, all is not lost! By delving into the python shell within your web container, we can directly add users through infogami, bypassing the typical process account creation process.
First, we have to execute the Python REPL within the web
container in Docker; one way to accomplish this is docker compose web exec python
.
From here, we have to load up Infogami, and get it started.
import web
import infogami
from openlibrary.config import load_config
load_config('conf/openlibrary.yml') # for local dev
# load_config('/olsystem/etc/openlibrary.yml') # for prod
infogami._setup()
from infogami import config
from infogami.infobase import server
These commands get the necessary portions of infogami and the open library running. (Tip: While ctrl + V does not function to paste sections of code into the python command-line, right clicking will paste whatever's stored in your clipboard. If you're on Mac, or otherwise don't have right functionality, you might have to manually enter the code. Shift+Insert will also paste on some configurations.)
To test that this is working as intended, type web.ctx.site
into the REPL. If it doesn't show up, something has gone wrong.
>>> web.ctx.site
<infogami.infobase.client.Site object at 0x7506c00c84d0>
Next, we run the account creation process through the connection in web.ctx.site
. (If you want to look further into what's being done, the relevant class is located in Infogami.infobase.client.py
.)
>>> web.ctx.site.register('test_username', 'test_displayname', '[email protected]', 'test_password')
0.0 (5): SELECT * FROM store WHERE key='account/test_username'
0.03 (2): 200 POST /openlibrary.org/account/register {'username': 'test_username', 'displayname': 'test_displayname', 'email': '[email protected]', 'password': 'test_password'}
<Storage {'activation_code': None, 'email': '[email protected]'}>
Keep in mind the email that you use here; it'll be necessary for logging in.
Next, we have to initialize the site on the server's end, to be able to properly activate the account.
site = server.get_site('openlibrary.org')
site.account_manager.activate(<username>)
At this point, the account should be activated. However, we're not quite finished. In order to login, we have to edit how the program spoofs the information that would normally be returned by the internet archive.
In openlibrary.plugins.upstream.account.py
, there should be a class called xauth
.
In order to log-in to an account, result['itemname'] on line 121 (on this image), must be set to the account's username that you are trying to log into.
Once this is set, you should be able to log into that account with the same email on your typical log-in screen. Remember; in order to access your admin account again, you'll have to change the item name back to @openlibrary
.
Depending on the behavior that you are trying to recreate locally, it might become necessary to add your users to different user groups. For example, you may need to create merge requests using a user assigned to the librarians usergroup in order to test the merge process. The test user that you have created following the above instructions will only have basic permissions and will not be able to access librarian tools. By adding that user to the librarians usergroup, you will be able to log in as that user and access the functionality that you wish to test. With your local development instance running, the list of all usergroups can be viewed at http://localhost:8080/usergroup.
Following the librarian user example, we can find the librarians usergroup page at http://localhost:8080/usergroup/librarians. To add a user to a specific usergroup, open the page for that group from the list pictured above and append, ?m=edit
, to the end of the url. This will load the edit form for that usergroup which will allow you to add your newly created user.
In the above screenshot, the librarians usergroup is being edited at the url, http://localhost:8080/usergroup/librarians?m=edit. To add your user, in the members section, enter /people/
followed by the user's screen name (/people/test_username
for the user, test_username
, in the above example) and then click save once you are finished. After saving your changes, any valid users that you have added should now be added to that specific usergroup. You can verify this by logging in as that user and ensuring that the appropriate pages for that usergroup are now accessible. You can also check by navigating to the newly updated usergroup page to see if the user appears in the list of usergroup members.