Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mirego/elixir-boilerplate
⚗ The stable base upon which we build our Elixir projects at Mirego.
https://github.com/mirego/elixir-boilerplate
absinthe absinthe-graphql credo dialyzer docker ecto elixir elixir-lang elixir-phoenix gettext graphql otp plug
Last synced: 1 day ago
JSON representation
⚗ The stable base upon which we build our Elixir projects at Mirego.
- Host: GitHub
- URL: https://github.com/mirego/elixir-boilerplate
- Owner: mirego
- License: bsd-3-clause
- Created: 2019-03-18T19:02:00.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2024-06-24T19:54:52.000Z (7 months ago)
- Last Synced: 2025-01-17T09:04:47.338Z (9 days ago)
- Topics: absinthe, absinthe-graphql, credo, dialyzer, docker, ecto, elixir, elixir-lang, elixir-phoenix, gettext, graphql, otp, plug
- Language: Elixir
- Homepage: https://open.mirego.com
- Size: 1.49 MB
- Stars: 1,139
- Watchers: 51
- Forks: 83
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-boilerplate - Elixir Boilerplate
README
This repository is the stable base upon which we build our Elixir projects at Mirego.
We want to share it with the world so you can build awesome Elixir applications too.
## Introduction
To learn more about _why_ we created and maintain this boilerplate project, read our [blog post](https://shift.mirego.com/en/boilerplate-projects).
## Content
This boilerplate comes with batteries included, you’ll find:
- [Phoenix](https://phoenixframework.org), the battle-tested production-ready web framework
- Database integration using [Ecto](https://hexdocs.pm/ecto)
- GraphQL API setup with [Absinthe](https://hexdocs.pm/absinthe), [Absinthe.Plug](https://hexdocs.pm/absinthe_plug), [Dataloader](https://hexdocs.pm/dataloader), [AbsintheErrorPayload](https://hexdocs.pm/absinthe_error_payload) and [AbsintheSecurity](https://hexdocs.pm/absinthe_security)
- Translations with [Gettext](https://hexdocs.pm/gettext) and [Accent](https://www.accent.reviews) (using a scheduled GitHub Actions [workflow](./.github/workflows/accent.yaml))
- [ExUnit](https://hexdocs.pm/ex_unit) tests, factories using [ExMachina](https://hexdocs.pm/ex_machina) and code coverage using [ExCoveralls](https://hexdocs.pm/excoveralls)
- CORS management with [Corsica](https://github.com/whatyouhide/corsica)
- Opinionated linting with [Credo](http://credo-ci.org)
- Security scanning with [MixAudit](https://hex.pm/packages/mix_audit) and [Sobelow](https://hexdocs.pm/sobelow)
- Healthcheck setup with [plug_checkup](https://hexdocs.pm/plug_checkup)
- OTP release using [`mix release`](https://hexdocs.pm/mix/Mix.Tasks.Release.html) and [Docker](https://www.docker.com)
- Useful utilities for web features: Basic authentication with [BasicAuth](https://hexdocs.pm/plug/Plug.BasicAuth.html), canonical host with [PlugCanonicalHost](https://hexdocs.pm/plug_canonical_host), etc.
- Error reporting with [Sentry](https://hexdocs.pm/sentry)
- A clean and useful `README.md` template (in both [english](./BOILERPLATE_README.md) and [french](./BOILERPLATE_README.fr.md))
- Dashboard metrics using [TelemetryUI](https://github.com/mirego/telemetry_ui)## Usage
### With GitHub template
1. Click on the [**Use this template**](https://github.com/mirego/elixir-boilerplate/generate) button to create a new repository
2. Clone your newly created project (`git clone https://github.com/you/repo.git`)
3. Run the boilerplate setup script (`./boilerplate-setup.sh YourProjectName`)
4. Commit the changes (`git commit -a -m "Rename elixir-boilerplate parts"`)### Without GitHub template
1. Clone this project (`git clone https://github.com/mirego/elixir-boilerplate.git`)
2. Delete the internal Git directory (`rm -rf .git`)
3. Run the boilerplate setup script (`./boilerplate-setup.sh YourProjectName`)
4. Create a new Git repository (`git init`)
5. Create the initial Git commit (`git commit -a -m "Initial commit"`)## Preferred libraries
Some batteries aren’t included since all projects have their own needs and requirements. Here’s a list of our preferred libraries to help you get started:
| Category | Libraries |
| --------------------------- | -------------------------------------------------------------------------------------- |
| Authentication | [`ueberauth`](https://hex.pm/packages/ueberauth), [`pow`](https://hex.pm/packages/pow) |
| Asynchronous job processing | [`oban`](https://hex.pm/packages/oban) |
| Emails | [`bamboo`](https://hex.pm/packages/bamboo), [`swoosh`](https://hex.pm/packages/swoosh) |
| File upload | [`waffle`](https://hex.pm/packages/waffle) |
| HTTP client | [`tesla`](https://hex.pm/packages/tesla) |
| HTML parsing | [`floki`](https://hex.pm/packages/floki) |
| Pagination | [`scrivener`](https://hex.pm/packages/scrivener) |
| Mocks | [`mox`](https://hex.pm/packages/mox), [`mimic`](https://hex.pm/packages/mimic) |
| Search | [`elasticsearch`](https://hex.pm/packages/elasticsearch) |## License
Elixir Boilerplate is © 2017-2020 [Mirego](https://www.mirego.com) and may be freely distributed under the [New BSD license](http://opensource.org/licenses/BSD-3-Clause). See the [`LICENSE.md`](https://github.com/mirego/elixir-boilerplate/blob/main/LICENSE.md) file.
The drop logo is based on [this lovely icon by Creative Stall](https://thenounproject.com/term/drop/174999), from The Noun Project. Used under a [Creative Commons BY 3.0](http://creativecommons.org/licenses/by/3.0/) license.
## About Mirego
[Mirego](https://www.mirego.com) is a team of passionate people who believe that work is a place where you can innovate and have fun. We’re a team of [talented people](https://life.mirego.com) who imagine and build beautiful Web and mobile applications. We come together to share ideas and [change the world](http://www.mirego.org).
We also [love open-source software](https://open.mirego.com) and we try to give back to the community as much as we can.