prepare for dokku deploy

This commit is contained in:
2025-06-22 11:06:13 +02:00
parent 98b28bcd4f
commit 387db3e708
2 changed files with 71 additions and 85 deletions

View File

@@ -1,24 +1,82 @@
# README
# Plays Hub
This README would normally document whatever steps are necessary to get the
application up and running.
A Rails application for tracking and visualizing your Spotify listening statistics.
Things you may want to cover:
## Setup Instructions
* Ruby version
### 1. Prerequisites
- Ruby (see `.ruby-version` or Gemfile for version)
- PostgreSQL
- Node.js & Yarn (for JS/CSS assets)
- Redis (if using caching or background jobs)
* System dependencies
### 2. Clone the Repository
```sh
git clone <your-repo-url>
cd plays-hub
```
* Configuration
### 3. Install Dependencies
```sh
bundle install
yarn install --check-files
```
* Database creation
### 4. Environment Variables
Create a `.env` file (or set these in your environment):
* Database initialization
| Variable | Description |
|----------------------------------|------------------------------------------|
| `SPOTIFY_CLIENT_ID` | Your Spotify App Client ID |
| `SPOTIFY_CLIENT_SECRET` | Your Spotify App Client Secret |
| `SPOTIFY_REDIRECT_URI` | Your app's public base URL (no trailing slash), e.g. `https://yourdomain.com` |
| `PLAYS_HUB_DATABASE_PASSWORD` | Password for the main production database |
| `PLAYS_HUB_QUEUE_DATABASE_PASSWORD` | Password for the Solid Queue DB (production) |
| `RAILS_ENV` | (optional) Rails environment, e.g. `development` |
| `PORT` | (optional) Port to run the Rails server |
* How to run the test suite
### 5. Database Setup
```sh
rails db:create db:migrate
rails db:queue_migrate
```
* Services (job queues, cache servers, search engines, etc.)
### 6. Running the App
```sh
rails server
```
* Deployment instructions
### 7. Background Jobs
- This app uses [Solid Queue](https://github.com/basecamp/solid_queue) for background jobs.
- Jobs are scheduled via `config/recurring.yml` (e.g., to fetch Spotify activities regularly).
- To run background jobs:
```sh
bin/rails solid_queue:start
```
* ...
### 8. Spotify Integration
- On first login, users must connect their Spotify account.
- Make sure your Spotify app's redirect URI matches `SPOTIFY_REDIRECT_URI` + `/spotify_callback`.
### 9. Running Tests
```sh
bundle exec rspec
```
---
## Environment Variables Summary
- `SPOTIFY_CLIENT_ID`
- `SPOTIFY_CLIENT_SECRET`
- `SPOTIFY_REDIRECT_URI`
- `PLAYS_HUB_DATABASE_PASSWORD`
- `PLAYS_HUB_QUEUE_DATABASE_PASSWORD`
Set these in your `.env` or via your deployment provider's secrets manager.
---
## Additional Notes
- See `config/recurring.yml` for scheduled jobs.
- See `Gemfile` for required gems.
- For any issues, check logs and ensure all ENVs are set correctly.