🌋 Olympus is the web-based dashboard for the Ariadne project. It works with Dionysus to display summary statistics of all the user-submitted reports of deceptive design, along with a preview of the most recent reports. It is powered by Nuxt v3 and Tailwind CSS.
Olympus also makes use of the Auth0 SDK, which allows for login functionality. At the moment Olympus does not include functionality that necessitates login, but in the future this could allow administrators to delete reports on user request, allow registered users to verify, dispute, and comment on reports, etc., although this is not currently planned and is beyond the current scope of the Ariadne research project.
You will need Node.js (v16 or higher). We recommend installing the latest LTS version.
Install the dependencies:
npm install
You will also need an Auth0 account and a configured Auth0 application. You can sign up for a free account here. Once you have an account, you can create an application here. You will need to configure the following settings:
- Allowed Callback URLs:
http://localhost:3000/
- Allowed Logout URLs:
http://localhost:3000/
- Allowed Web Origins:
http://localhost:3000/
If you will deploy Olympus publicly, you will need to add the appropriate URLs to these settings.
You will also need to take note of your Auth0 domain and client ID. You can find these in the Settings tab of your Auth0 application.
Save these values in a .env
file in the root of the project:
NUXT_PUBLIC_AUTH_DOMAIN="********************"
NUXT_PUBLIC_AUTH_CLIENT_ID="********************"
NUXT_PUBLIC_API_BASE_URL="http://localhost:5000"
Change NUXT_PUBLIC_API_BASE_URL
to whatever domain and port Dionysus is listening on.
Olympus is a Nuxt app, which means that you can
- start the development server on
http://localhost:3000
usingnpm run dev
, - build the application for production using
npm run build
, and - locally preview the production build using
npm run preview
.
When building for production, Vite will output a server at .output/server/index.mjs
. You can run this server using node .output/server/index.mjs
, and it will listen on port 3000 by default.
Olympus is Dockerized, so as long as you have a working Docker Compose stack with Dionysus and an accompanying PostgreSQL container, you can simply pull the image from Docker Hub and create a container with it.
You can use the following docker-compose.yml
file as a starting point:
version: '3.8'
services:
database:
container_name: dionysus-db
image: postgres:alpine
environment:
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
- POSTGRES_DB=dionysus
user: postgres
volumes:
- dionysus_db:/var/lib/postgresql/data
healthcheck:
test: ['CMD', 'pg_isready']
interval: 1s
timeout: 1s
retries: 3
start_period: 1s
restart: always
backend:
container_name: dionysus
image: jareddantis/wsg-ariadne-dionysus:latest
depends_on:
database:
condition: service_healthy
ports:
- '5000:5000'
healthcheck:
test: ['CMD', 'curl', '-f', 'http://localhost:5000/api/v1/healthcheck']
interval: 1s
timeout: 5s
retries: 5
start_period: 30s
volumes:
- /PATH/TO/dionysus.conf:/opt/app/dionysus.conf
restart: unless-stopped
olympus:
container_name: olympus
image: jareddantis/wsg-ariadne-olympus:latest
depends_on:
backend:
condition: service_healthy
environment:
- NUXT_PUBLIC_AUTH_DOMAIN="**********************"
- NUXT_PUBLIC_AUTH_CLIENT_ID="**********************"
- NUXT_PUBLIC_API_BASE_URL="https://ariadne.dantis.me"
- NUXT_API_BASE_URL="http://localhost:5000"
ports:
- '5002:3000'
restart: unless-stopped
volumes:
dionysus_db: