Skip to main content

A game server for hosting text-based online MOO-like games.

Project description

DjangoMOO

"LambdaMOO on Django"

release pipeline coverage quality docs

DjangoMOO is a game server for hosting text-based online MOO-like games.

Quick Start

Checkout the project and use Docker Compose to run the necessary components:

git clone https://gitlab.com/bubblehouse/django-moo
cd django-moo
docker compose up

Run migrate, collectstatic, and bootstrap the initial database with some sample objects and users:

docker compose run webapp manage.py migrate
docker compose run webapp manage.py collectstatic
docker compose run webapp manage.py moo_init
docker compose run webapp manage.py createsuperuser --username phil
docker compose run webapp manage.py moo_enableuser --wizard phil Wizard

Now you should be able to connect to https://localhost/ and login with the superuser you just created, described below.

Login via Web

To make things easier for folks without SSH access or who are behind firewalls, the server interface is exposed through webssh.

WebSSH Client Example WebSSH Editor Example

This client is only able to open connections to the local SSH server.

Admin Interface

As a secondary way to view the contents of a running server, a Django Admin interface is available at /admin. It's really a last resort for most things:

Django Admin Example

Login via SSH

Of course, it's also possible (perhaps even preferred) to connect directly over SSH:

SSH Client Example

It's also possible to associate an SSH Key with your user in the Django Admin so as to skip the password prompt.

When you're done exploring, you can hit Ctrl-D to exit.

LambdaCore Attributions

This package is heavily derived from the LambdaMOO and LambdaCore documentation, including the LambdaCore Programmer's Manual and the LambdaMOO Programmer's Manual. The code was written without reading the original LambdaCore source; it is an independent reimplementation based on documented behavior and conventions.

Various verbs have been modified from their LambdaCore equivalents to better fit a Pythonic codebase: output uses print() rather than return values, property access follows Django ORM patterns, and permission idioms have been updated to account for differences in how this server dispatches verbs compared to LambdaMOO.

DjangoMOO could not have happened without the work of the following authors:

  • LambdaCore Database User's Manual (LambdaMOO 1.3, April 1991) Mike Prudence (blip), Simon Hunt (Ezeke), Floyd Moore (Phantom), Kelly Larson (Zaphod), Al Harrington (geezer)

  • LambdaCore Programmer's Manual (LambdaMOO 1.8.0p6, Copyright 1991) Mike Prudence (blip), Simon Hunt (Ezeke), Floyd Moore (Phantom), Kelly Larson (Zaphod), Al Harrington (geezer)

  • LambdaMOO Programmer's Manual (LambdaMOO 1.8.0p6, March 1997) Pavel Curtis (Haakon / Lambda)

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_moo-0.94.0.tar.gz (558.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_moo-0.94.0-py3-none-any.whl (422.2 kB view details)

Uploaded Python 3

File details

Details for the file django_moo-0.94.0.tar.gz.

File metadata

  • Download URL: django_moo-0.94.0.tar.gz
  • Upload date:
  • Size: 558.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for django_moo-0.94.0.tar.gz
Algorithm Hash digest
SHA256 69ae8d940ec6bc6bce48f5f01da1ed2be1bf9ea9b01ff32cdc803dc9d4a7f93b
MD5 a184decd204051afb03242942a3fd833
BLAKE2b-256 c0898847dc63ea53078136b6d12efe0ef664d2773c6b9fee9eff4ed7a76ec110

See more details on using hashes here.

File details

Details for the file django_moo-0.94.0-py3-none-any.whl.

File metadata

  • Download URL: django_moo-0.94.0-py3-none-any.whl
  • Upload date:
  • Size: 422.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for django_moo-0.94.0-py3-none-any.whl
Algorithm Hash digest
SHA256 79b381ae09569e4e3bd5b389095c98dc59e000a05a03ad5bec6d672f8bb76243
MD5 6937f164d6f10f5cd710b0f9a3db0a7f
BLAKE2b-256 177d7c002e2417db80b43de12f778a37368286c8a63ec6b2bc368be3b99f341e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page