Skip to main content

A web-appication for the administration of alfred experiments.

Project description

Welcome to Mortimer

Mortimer is a free, open source web application written in the Flask Framework. It's purpose is to host and manage Alfred experiments and surveys.

IMPORTANT NOTE: Mortimer is currently not easy to set up and use safely. Please contanct us, if you want to use it. Most importantly, you should allow only trusted users to register.

Installation

Prerequisites

  • Python 3.7 or newer installed
  • A MongoDB instance with authentication enabled.
    • For MongoDB installation on Debian servers, you can refer to the official installation guide.
    • Create a databse "mortimer" and a database "alfred" in your MongoDB instance. The "mortimer" db will be used for user management and deployment of Alfred experiments. The "alfred" database will be used by Alfred to store experimental data.
  • Refer to the MongoDB security checklist to ensure adequate security of your database.

Installation

IMPORTANT NOTE: Mortimer is currently not easy to set up and use safely. Please contanct us, if you want to use it. Most importantly, you should only ever allow trusted users to register.

pip install mortimer

Configure Mortimer

Now you need to configure mortimer. You have the following options on where to place it:

  1. If you are operating on a unix-based operating system, you can create a file mortimer.conf in /etc.
  2. You can create a file mortimer.conf in your user home directory.
  3. You can create a file mortimer.conf in a directory of your choosing and set the directory path (not the full path to the file) as an environment variable with the key MORTIMER_CONFIG.
  4. You can create a file mortimer.conf in your instance path.

You only need to use one of these options. If you don't know which one to use, we recommend to place the configuration fiel in your instance directory. The files are read in that order, later files override earlier ones.

For a minimal setup, you need to specify the following settings.

Notes:

  • The mongoDB user needs to have the following roles:
    • userAdmin role on the "alfred" database.
    • readWrite role on the "mortimer" dabatase.
    • read role on the "alfred" database.
# General flask settings
SECRET_KEY =            # Must be URL-safe base64-encoded 32-byte key for fernet encryption in STR (NOT in bytes)
PAROLE =                # a passphrase that new users need to enter upon registration
DEBUG =                 # True or False

# flask-mongoengine settings
MONGODB_SETTINGS = {
    "host": "localhost",
    "port": 27017,
    "username": "<username>",
    "password": "<password>"
}

Start

Before starting, you need to create a run.py and specify your instance path. The run.py will look like this:

from mortimer import create_app

path = "" # fill in your instance path here!

app = create_app(instance_path=path)

if __name__ == "__main__":
    app.run(debug=True)

You are now ready to start Mortimer. In a shell, execute the following command (make sure that you are inside the mortimer directory):

export FLASK_APP=run.py
flask run

This will allow you to access Mortimer locally via 127.0.0.1/5000 from your webbrowser. You can make the app available externally with these commands:

export FLASK_APP=run.py
flask run --host=0.0.0.0 --port=5000

Important Note: Do not use this in a production setting. It is not intended to meet security and performance requirements for a production server. Instead, see Flasks Deployment Options for WSGI server recommendations.

IMPORTANT NOTE: Mortimer is currently not easy to set up and use safely. Please contanct us, if you want to use it. Most importantly, you should allow only trusted users to register.

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

mortimer-0.8.13b0.tar.gz (985.8 kB view details)

Uploaded Source

Built Distribution

mortimer-0.8.13b0-py3-none-any.whl (1.0 MB view details)

Uploaded Python 3

File details

Details for the file mortimer-0.8.13b0.tar.gz.

File metadata

  • Download URL: mortimer-0.8.13b0.tar.gz
  • Upload date:
  • Size: 985.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.10.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.7.12

File hashes

Hashes for mortimer-0.8.13b0.tar.gz
Algorithm Hash digest
SHA256 1fbe12e8df92611c11ca21cfe499d1b585b11261d89a48baceffc8b55e77d2a4
MD5 0699dc7a627a0ce70cacdef4c29342d4
BLAKE2b-256 e80305e0f8dd322cba4551ce35e9d9ea32e9ccccae733262da6f23e16da4cf63

See more details on using hashes here.

File details

Details for the file mortimer-0.8.13b0-py3-none-any.whl.

File metadata

  • Download URL: mortimer-0.8.13b0-py3-none-any.whl
  • Upload date:
  • Size: 1.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.10.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.7.12

File hashes

Hashes for mortimer-0.8.13b0-py3-none-any.whl
Algorithm Hash digest
SHA256 ea7cdcb15fdd17f728f6da8cfe72970dffba520f68f8e2cfb104838b2eabfba5
MD5 1833c99eeee1273afbcf1711093ddbab
BLAKE2b-256 921c79fe1c0ceed47db63c8a472b01f9c6201865e115259bbde4b0a0a68f184d

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