A server-side web application designed for managing parking lot' authorized drivers and vehicles along with the automated parking registrations powered by ALPR.
Using Visual Studio Code, first, make sure the Dev Containers
extension is installed.
Then open the project inside the Dev Container by typing Ctrl/Cmd + Shift + P and selecting Dev Containers: Reopen in Container
.
It should automatically set up the environment and install the dependencies. If not, just run mix setup
inside the terminal.
Finally, run the server with mix phx.server
and open the browser at http://localhost:4000.
First, make sure you have Docker properly setup on the server. Then we can start a database container with the following command:
docker run -d \
--name parking-lot-database \
-e POSTGRES_PASSWORD=postgres \
-e POSTGRES_DB=parking_lot \
-p 5432:5432 \
-v postgres:/var/lib/postgresql/data \
--restart unless-stopped \
postgres:latest
Check the official documentation for more information about the
postgres
image.
Now we should define the environment variables required for the application to work. We can do that by creating a .env
file with the following content:
DATABASE_URL=ecto://postgres:[email protected]:5432/parking_lot
SECRET_KEY_BASE=my_ramdom_secure_and_at_least_64_bits_long_secret_______________
PHX_HOST=127.0.0.1
CACHE_DIR=/data
Then we should pull the latest application image running:
docker pull ghcr.io/wigny/parking_lot:latest
Now let's run the migrations on the database:
docker run --env-file path/to/env/file.env -it ghcr.io/wigny/parking_lot bin/migrate
Finally, we can start the application container:
docker run -itd \
--name parking-lot \
-p 4000:4000 \
-v /tmp:/data \
--env-file path/to/env/file.env \
--restart unless-stopped \
ghcr.io/wigny/parking_lot
We can now setup the users of the application by connecting to the remote console:
$ docker container exec -it parking-lot bin/parking_lot remote
iex> ParkingLot.Accounts.create_user(%{email: "[email protected]", password: "password", admin: true})
iex> ParkingLot.Accounts.create_user(%{email: "[email protected]", password: "password", admin: false})
The application should start serving on port 4000
of the configured PHX_HOST
.