Welcome to the Montage Project! This guide will help you set up the project for local development.
The Montage Project is a web application with two main components:
-
Frontend:
- Built with Vue 3.
- Includes Wikimedia Codex for UI components, Axios for API requests, and Pinia for state management.
- Compiled using Vite for fast builds.
-
Backend:
- Built with Clastic, a Python framework.
- Uses various Python libraries such as:
- SQLAlchemy: Database interactions.
- mwoauth: Used for authentication with MediaWiki’s OAuth.
- pymysql: MySQL driver.
- Serves the frontend and exposes API endpoints for application functionality.
Ensure the following are installed:
- Docker and Docker Compose: Install Docker.
- Node.js (v16 or above): Install Node.js.
- Make: Available on most Unix-based systems.
git clone git@github.com:hatnote/montage.git
cd montage
cd frontend
npm install
npm run watch:build
npm run watch:build
above will watch for changes by using chokidar
command and automatically copied to the backend's static
and template
directories. So there will not be any hot reloading. Developers must refresh the browser to see updates.
Apart from npm watch:build
, these are other commands:
npm run lint
: Lint the codenpm run format
: Format the code
- Open a new terminal tab and change directory to root of repo
- Copy and edit
config.dev.yaml
based onconfig.default.yaml
- (Optional) In
config.dev.yaml
there is a line fordev_local_cookie_value
. To get it, log in to the local app in your browser, and then copy the value from theclastic_cookie
in the apps' cookies. This is your login cookie. - (Optional) Add your username as the
superuser
in the config. (This will allow you to addsu_to=<any user>
to the backend, if you want to test submitting as another juror.) - Add your username to the list of maintainers in rdb.py line 113. This will give your user top-level permissions in the full app, so you can view some logs (audit logs, active users), add/remove organizers, and get a coordinator view into all campaigns.
- Start the montage backend
make start
This will build the docker image for the montage backend and start the container. Apart from make start
, these are other commands:
make start-detached
: Start the backend container in detached modemake stop
: Stop the backend containermake logs
: Stream the backend container logs in real-time.make restart
: Restart the backend container
- Open http://localhost:5001 in your browser.
The application server runs on localhost port 5001, visit http://localhost:5001/meta to see a list of valid URL patterns and other details.
Almost all endpoints from backend (except for OAuth and /static/
) return JSON as long as the proper Accept header is set (done by most libraries) or format=json
is passed in the query string.
├── DEV.md
├── Dockerfile
├── LICENSE
├── MANIFEST.in
├── Makefile
├── PROJECT_LOG.md
├── config
│ ├── beta-uwsgi.ini
│ ├── dev-uwsgi.ini
│ └── prod-uwsgi.ini
├── config.default.yaml
├── deployment.md
├── design.md
├── docker-compose.yml
├── frontend
│ ├── index.html
│ ├── jsconfig.json
│ ├── package-lock.json
│ ├── package.json
│ ├── public
│ ├── src
│ └── vite.config.js
├── montage
│ ├── __init__.py
│ ├── __main__.py
│ ├── __pycache__
│ ├── admin_endpoints.py
│ ├── app.py
│ ├── check_rdb.py
│ ├── clastic_sentry.py
│ ├── docs
│ ├── imgutils.py
│ ├── juror_endpoints.py
│ ├── labs.py
│ ├── loaders.py
│ ├── log.py
│ ├── meta_endpoints.py
│ ├── mw
│ ├── public_endpoints.py
│ ├── rdb.py
│ ├── rendered_admin.py
│ ├── server.py
│ ├── simple_serdes.py
│ ├── static
│ ├── templates
│ ├── tests
│ └── utils.py
├── report.html
├── requirements-dev.txt
├── requirements.in
├── requirements.txt
├── setup.py
├── tools
│ ├── _admin.py
│ ├── admin.py
│ ├── check_schema.py
│ ├── create_schema.py
│ ├── drop_schema.py
│ └── trim_csv.py
└── tox.ini
These provides a detailed explanation of the main components in the Montage Project.
app.py
: Initializes the application and defines middleware, routes, or app-wide configurations.server.py
: Starts the server, setting up the backend to listen on a specific port.__main__.py
: Entry point when running the backend module.
admin_endpoints.py
: Handles admin-specific routes (e.g., user management, settings).juror_endpoints.py
: Contains juror-related APIs (e.g., task assignments, voting).meta_endpoints.py
: General application metadata or system information.public_endpoints.py
: APIs accessible to public or unauthenticated users.
imgutils.py
: Handles image processing and manipulation.simple_serdes.py
: Serializes and deserializes objects to JSON or other formats.log.py
: Configures application logging.
rdb.py
: Manages database interactions (queries, migrations, etc.).check_rdb.py
: Verifies database schema integrity.
static/
: Holds CSS, JavaScript, and other assets.templates/
: Contains Jinja2 templates for dynamic HTML rendering.
tests/
: Basic tests for backend components.
src/
: Source code, including components, routes, and utilities.public/
: Static assets, such as images and global styles.vite.config.js
: Configuration for the Vite build tool.
create_schema.py
: Creates database tables.drop_schema.py
: Drops all database tables.check_schema.py
: Verifies schema correctness.trim_csv.py
: Utility for cleaning CSV files
Dockerfile
: Builds the backend container.docker-compose.yml
: Orchestrates service for backend.