bootstrap/specs/phoenix/template
Joshua Potter 42e71e6493 Encourage the use ob abstract sockets. 2023-12-01 10:06:17 -07:00
..
.githooks Add formatting pre-commit to elixir projects. 2023-11-29 09:18:10 -07:00
.envrc Add formatting pre-commit to elixir projects. 2023-11-29 09:18:10 -07:00
README.md Encourage the use ob abstract sockets. 2023-12-01 10:06:17 -07:00
default.nix Add phoenix spec. 2023-11-28 09:21:31 -07:00
deps.nix Add phoenix spec. 2023-11-28 09:21:31 -07:00
flake.lock Add phoenix spec. 2023-11-28 09:21:31 -07:00
flake.nix Add phoenix spec. 2023-11-28 09:21:31 -07:00

README.md

Phoenix Flake Template

This is a template for constructing a environment for Elixir development (version 1.15.7, Erlang/OTP 25) with the Phoenix (version 1.7.10) framework. direnv can be used to launch a dev shell upon entering this directory (refer to .envrc). Otherwise run via:

$> nix develop

Quickstart

An empty Postgres cluster is initialized at /db. To start the database, run the following:

$> pg_ctl -D db -l db/logfile -o --unix_socket_directories=@phoenix start

In the above command, @phoenix refers to an abstract socket name. Rename to whatever is appropriate for your use case. To then connect to this database instance, run:

$> psql -h @phoenix

To later shut the database down, run:

$> pg_ctl -D db stop

Afterward, you can run the Phoenix setup commands:

$> mix ecto.setup
$> mix assets.setup

and then start the local server:

$> mix phx.server

Dependencies

This project pins Mix dependencies using mix2nix. After updating your mix.lock file, make sure to re-run the following:

$> mix2nix > deps.nix

As of now, mix2nix cannot handle git dependencies found inside the mix.lock file. If you have git dependencies, add them manually or use FODs.

Language Server

The elixir-ls LSP (version 0.17.10) is included in this flake.

Formatting

Formatting depends on the mix format task. A pre-commit hook is included in .githooks that can be used to format all *.exs? files prior to commit. Install via:

$> git config --local core.hooksPath .githooks/

If running direnv, this hook is installed automatically when entering the directory.