ExPomodoro

The ex_pomodoro program is a simple set of functions that let developers manage pomodoro sessions withing their Elixir applications.

An Elixir Pomodoro 🍅

CI StatusCoverage Status

License

Introduction

About the Pomodoro technique

ExPomodoro is an Elixir library that let developers easily manage pomodoro sessions by using a simple set of fuctions that can start a pomodoro session, pause a session, get the current session details.

The motivation behind ExPomodoro development was initially driven by HTTP integrations in chat applications, such as Mattermost or Slack, where one could create slash commands that interact to an HTTP server or create bots that send and receive notifications. This library includes only the domain logic for managing pomodoro sessions.

Installation

If available in Hex, the package can be installed by adding ex_pomodoro to your list of dependencies in mix.exs:

def deps do
  [
    {:ex_pomodoro, "~> 1.0.0"}
  ]
end

Otherwise it can be installed using the git remote url:

def deps do
  [
    {:ex_pomodoro,
     git: "git@github.com:sgobotta/ex_pomodoro.git", tag: "1.0.0"}
  ]
end

Setup

ExPomodoro uses a Supervisor and GenServer to perform runtime operations for pomodoros. Add the ExPomodoro child spec to your application tree.

application.ex:

@impl true
def start(_type, _args) do
  children = [
      ...

      ExPomodoro # <- Add ExPomodoro to the children array
    ]

  opts = [strategy: :one_for_one, name: MyApp.Supervisor]
  Supervisor.start_link(children, opts)
end

Usage

The ExPomodoro is the main module to interact with the APIs using a Pomodoro struct. There should be no need to use the rest of modules that handle runtime logic.

A Pomodoro has four states: :idle, :exercise, :break, :finished

Calling the APIs affect the state, and return an updated Pomodoro struct.

All pomodoro functions are documented, check the ExPomodoro for more usage examples.

Start a pomodoro session

A %Pomodoro{} is created with an id that must be unique between sessions. Starting a pomodoro with a non-unique id will cause no effect.

This command will create a pomodoro with default options. The work time is 25 minutes by default, the break time is 5 and the number of periods is 4.

iex> ExPomodoro.start("some id")
{:ok, %ExPomodoro.Pomodoro{
  id: "some id",
  activity: :exercise,
  exercise_duration: 1_500_000,
  break_duration: 300_000,
  rounds: 4
}}

Check the ExPomodoro module docs for examples with options.

Pause a pomodoro session

A %Pomodoro{} can be paused by passing the id.

iex> ExPomodoro.pause("some id")
{:ok, %Pomodoro{
  id: "some id",
  activity: :idle,
  current_duration: timeleft
}}

Get a pomodoro session

A %Pomodoro{} can be obtained by passing the id.

iex> ExPomodoro.get("some id")
{:ok, %ExPomodoro.Pomodoro{id: "some id"}}

If the session does not exist, the function returns an error tuple.

iex> ExPomodoro.get("some other id")
{:error, :not_found}

A Pomodoro has a timeout of 90 minutes. if no interaction is made the Pomodoro will not be found and it’s stats lost.

Development

Requirements

If you use asdf just run asdf install in the root repository to install the required Elixir version.

Installation and setup

Install and compile dependencies and library.

make setup

Run format checks, credo, dialyzer and tests

make check

Run tests only

make test

Run test coverage

make test.cover

Run make to find a complete list of commands.

Future features

License

GNU General Public License version 3