Newer
Older
---
title: Development setup
sidebarDepth: 3
---
# Setup your development environment
## Introduction
Castopod is a web app based on the `php` framework
[CodeIgniter 4](https://codeigniter.com).
We use [Docker](https://www.docker.com/) quickly setup a dev environment. A
`docker-compose.yml` and `Dockerfile` are included in the project's root folder
to help you kickstart your contribution.
> You don't need any prior knowledge of Docker to follow the next steps.
> However, if you wish to use your own environment, feel free to do so!
## Setup instructions
### 1. Pre-requisites

Yassine Doghri
committed
0. Install [docker](https://docs.docker.com/get-docker).
1. Clone Castopod project by running:

Yassine Doghri
committed
```bash
git clone https://code.castopod.org/ad-aures/castopod.git

Yassine Doghri
committed
```
2. Create a `.env` file with the minimum required config to connect the app to
the database and use redis as a cache handler:

Yassine Doghri
committed
```ini
CI_ENVIRONMENT="development"
# If set to development, you must run `npm run dev` to start the static assets server
vite.environment="development"

Yassine Doghri
committed
# By default, this is set to true in the app config.
# For development, this must be set to false as it is
# on a local environment
app.forceGlobalSecureRequests=false

Yassine Doghri
committed

Yassine Doghri
committed
app.baseURL="http://localhost:8080/"
app.mediaBaseURL="http://localhost:8080/"

Yassine Doghri
committed
admin.gateway="cp-admin"
auth.gateway="cp-auth"

Yassine Doghri
committed
database.default.hostname="mariadb"
database.default.database="castopod"
database.default.username="castopod"

Yassine Doghri
committed
database.default.password="castopod"

Yassine Doghri
committed
cache.handler="redis"
cache.redis.host = "redis"

Yassine Doghri
committed
# You may not want to use redis as your cache handler
# Comment/remove the two lines above and uncomment
# the next line for file caching.
#cache.handler="file"
```

Yassine Doghri
committed
> _NB._ You can tweak your environment by setting more environment variables
> in your custom `.env` file. See the `env` for examples or the
> [CodeIgniter4 User Guide](https://codeigniter.com/user_guide/index.html)
> for more info.

Yassine Doghri
committed
3. (for docker desktop) Add the repository you've cloned to docker desktop's
`Settings` > `Resources` > `File Sharing`
### 2. (recommended) Develop inside the app Container with VSCode

Yassine Doghri
committed
If you're working in VSCode, you can take advantage of the `.devcontainer/`
folder. It defines a development environment (dev container) with preinstalled
requirements and VSCode extensions so you don't have to worry about them. All
required services will be loaded automagically! 🪄

Yassine Doghri
committed
1. Install the VSCode extension
[Remote - Containers](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers)
2. `Ctrl/Cmd + Shift + P` > `Open in container`
> The VSCode window will reload inside the dev container. Expect several
> minutes during first load as it is building all necessary services.
**Note**: The dev container will start by running Castopod's php server.
During development, you will have to start [Vite](https://vitejs.dev)'s dev
server for compiling the typescript code and styles:
```bash
# run Vite dev server
npm run dev
```
If there is any issue with the php server not running, you can restart them
using the following commands:
```bash
# run Castopod server
php spark serve - 0.0.0.0
```

Yassine Doghri
committed
3. You're all set! 🎉

Yassine Doghri
committed
You're now **inside the dev container**, you may use the VSCode console
(`Terminal` > `New Terminal`) to run any command:

Yassine Doghri
committed
```bash
# PHP is installed
php -v

Yassine Doghri
committed
# Composer is installed
composer -V

Yassine Doghri
committed
# npm is installed
npm -v

Yassine Doghri
committed
# git is installed
git version
```

Yassine Doghri
committed
For more info, see
[VSCode Remote Containers](https://code.visualstudio.com/docs/remote/containers)
### 3. Start hacking
You're all set! Start working your magic by updating the project's files! Help
yourself to the
[CodeIgniter4 User Guide](https://codeigniter.com/user_guide/index.html) for
more insights.
To see your changes, go to:
- `http://localhost:8080/` for the Castopod app
- `http://localhost:8888/` for the phpmyadmin interface:
- username: **castopod**
- password: **castopod**
### 2-alt. Develop outside the app container

Yassine Doghri
committed
You do not wish to use the VSCode devcontainer? No problem!

Yassine Doghri
committed
1. Start docker containers manually:

Yassine Doghri
committed
Go to project's root folder and run:

Yassine Doghri
committed
```bash
# starts all services declared in docker-compose.yml file
# -d option starts the containers in the background
docker-compose up -d

Yassine Doghri
committed
# See all running processes (you should see 3 processes running)
docker-compose ps

Yassine Doghri
committed
# Alternatively, you can check all docker processes
docker ps -a

Yassine Doghri
committed
```

Yassine Doghri
committed
> The `docker-compose up -d` command will boot 4 containers in the
> background:
>
> - `castopod_app`: a php based container with Castopod requirements
> installed
> - `castopod_redis`: a [redis](https://redis.io/) database to handle queries
> and pages caching
> - `castopod_mariadb`: a [mariadb](https://mariadb.org/) server for

Yassine Doghri
committed
> persistent data
> - `castopod_phpmyadmin`: a phpmyadmin server to visualize the mariadb

Yassine Doghri
committed
> database.
2. Run any command inside the containers by prefixing them with
`docker-compose run --rm app`:

Yassine Doghri
committed
```bash
# use PHP
docker-compose run --rm app php -v

Yassine Doghri
committed
# use Composer
docker-compose run --rm app composer -V

Yassine Doghri
committed
# use npm
docker-compose run --rm app npm -v

Yassine Doghri
committed
# use git
docker-compose run --rm app git version
```

Yassine Doghri
committed
---
## Going Further
### Install Castopod's dependencies

Yassine Doghri
committed

Yassine Doghri
committed
1. Install php dependencies with [Composer](https://getcomposer.org/)

Yassine Doghri
committed

Yassine Doghri
committed
```bash
composer install
```

Yassine Doghri
committed
::: info Note
The php dependencies aren't included in the repository. Composer will check
the `composer.json` and `composer.lock` files to download the packages with
the right versions. The dependencies will live under the `vendor/` folder.
For more info, check out the
[Composer documentation](https://getcomposer.org/doc/).
:::

Yassine Doghri
committed
2. Install javascript dependencies with [npm](https://www.npmjs.com/)

Yassine Doghri
committed
```bash
npm install
```
::: info Note
The javascript dependencies aren't included in the repository. Npm will check
the `package.json` and `package.lock` files to download the packages with the
right versions. The dependencies will live under the `node_module` folder.
For more info, check out the [NPM documentation](https://docs.npmjs.com/).
:::

Yassine Doghri
committed
3. Generate static assets:

Yassine Doghri
committed
```bash
# build all static assets at once
npm run build:static
# build specific assets

Yassine Doghri
committed
npm run build:icons
npm run build:svg
```
::: info Note
The static assets generated live under the `public/assets` folder, it
includes javascript, styles, images, fonts, icons and svg files.
:::
### Initialize and populate database

Yassine Doghri
committed
::: tip
You may skip this section if you go through the install wizard (go to
`/cp-install`).
:::

Yassine Doghri
committed

Yassine Doghri
committed
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
1. Build the database with the migrate command:
```bash
# loads the database schema during first migration
php spark migrate -all
```
You may need to undo the migration (rollback):
```bash
# rolls back database schema (deletes all tables and their content)
php spark migrate:rollback
```
2. Populate the database with the required data:
```bash
# Populates all required data
php spark db:seed AppSeeder
```
You may choose to add data separately:
```bash
# Populates all categories
php spark db:seed CategorySeeder
# Populates all Languages
php spark db:seed LanguageSeeder
# Populates all podcasts platforms
php spark db:seed PlatformSeeder
# Populates all Authentication data (roles definition…)
php spark db:seed AuthSeeder
```
3. (optionnal) Populate the database with test data:
- Populate test data (login: admin / password: AGUehL3P)

Yassine Doghri
committed
```bash
php spark db:seed TestSeeder
```
- Populate with fake podcast analytics:

Yassine Doghri
committed

Yassine Doghri
committed
php spark db:seed FakePodcastsAnalyticsSeeder

Yassine Doghri
committed
- Populate with fake website analytics:
```bash

Yassine Doghri
committed
php spark db:seed FakeWebsiteAnalyticsSeeder
```
TestSeeder will add an active superadmin user with the following credentials:
- username: **admin**
- password: **AGUehL3P**
### Useful docker / docker-compose commands
- Monitor the app container:
```bash
docker-compose logs --tail 50 --follow --timestamps app
```
- Interact with redis server using included redis-cli command:
```bash
docker exec -it castopod_redis redis-cli
```
- Monitor the redis container:
docker-compose logs --tail 50 --follow --timestamps redis
```
- Monitor the mariadb container:

Yassine Doghri
committed
docker-compose logs --tail 50 --follow --timestamps mariadb
- Monitor the phpmyadmin container:
```bash

Yassine Doghri
committed
docker-compose logs --tail 50 --follow --timestamps phpmyadmin
```
- Restart docker containers:
docker-compose restart
```
- Destroy all containers, opposite of `up` command:
docker-compose down

Yassine Doghri
committed
- Rebuild app container:
```bash

Yassine Doghri
committed
docker-compose build app
```
Check [docker](https://docs.docker.com/engine/reference/commandline/docker/) and
[docker-compose](https://docs.docker.com/compose/reference/) documentations for
more insights.
## Known issues

Yassine Doghri
committed
### Allocation failed - JavaScript heap out of memory

Yassine Doghri
committed
This happens when running `npm install`.
👉 By default, docker might not have access to enough RAM. Allocate more memory
and run `npm install` again.
### (Linux) Files created inside container are attributed to root locally

Yassine Doghri
committed
You may use Linux user namespaces to fix this on your machine:

Yassine Doghri
committed
::: info Note
Replace "username" with your local username
:::

Yassine Doghri
committed
1. Go to `/etc/docker/daemon.json` and add:
```json
{
"userns-remap": "username"
}
```
2. Configure the subordinate uid/guid:
```bash
# in /etc/subuid

Yassine Doghri
committed
username:1000:1
username:100000:65536
```
```bash
# in /etc/subgid

Yassine Doghri
committed
username:1000:1
username:100000:65536
```
3. Restart docker:
```bash
sudo systemctl restart docker
```
4. That's it! Now, the root user in the container will be mapped to the user on
your local machine, no more permission issues! 🎉

Yassine Doghri
committed
You can check
[this great article](https://www.jujens.eu/posts/en/2017/Jul/02/docker-userns-remap/)
to know more about how it works.