- Install Crystal Language
- Run
shards build
from the root of the project
Note: The service is a precompiled program that can be run by simply executing
./bin/brightwheel
from the root of the project directory using a terminal.
- Run
source .env
from console and project root to load the environment variables (Using bash) - Run
./bin/brightwheel
to start the service
From the project root using a console/terminal:
Console 1:
- Run
shards build
- Run
source .env
- Run
./bin/brightwheel
Console 2:
- Run
source .env
from console and project root to load the environment variables (Using bash) - Run
crystal spec
The language choosen is Crystal Language.
Why: I choose this language because of code readability, type safe and speed. In a real world application I would choose GO Lang, Ruby or Java, in that order.
Azu Framework - https://github.com/azutoolkit/azu
Why: The framework chosen offer me to write simple programs with little boiler plate code. The framework allows me to choose my preferred project organizational structure for the project at hand. Note I am a big fan of this programming language, and I wrote the AmberFramework which is the second most used framework in the language for web/api development. I have also written AZU based on my learning experience from Amber (https://amberframework.org/).
Halite
Allows me to write HTTP Requests with a chainable REST API, built-in sessions and middleware
I would like to understand better the requirements around the resiliency needed so that I can better organize the adapter layer, there are ways to load the right adapter dynamically for retries and ensure delivery.
Another observation, I noticed that one of the requirements state as follows:
Convert the body HTML to a plain text version to send along to the email provider.
I purposely left this out because I did not see it being used currently. Not sure if I am missing something. I assuming this will be used later on and I will rather wait until then to implement it.
Service configuration uses environment variables this is to follow best practices as stated in the 12 factor principles for portability and configuration https://12factor.net/
When designing APIs I like to follow API Design first approach in which I create an open api spec for this case I did not deem it necessary, so I left this out for the interview.
- Fork it (https://github.com/your-github-user/brightwheel/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- Elias Perez - creator and maintainer