aboutsummaryrefslogtreecommitdiff
path: root/internal (follow)
Commit message (Collapse)AuthorAgeFilesLines
* don't check errorsFranck Cuny2025-08-293-3/+8
|
* check returned error when running the scrobblerFranck Cuny2025-08-291-1/+0
|
* fix import paths for mpd-scrobblerFranck Cuny2025-08-291-2/+3
|
* scrobbler: read mpd status before processing songFranck Cuny2021-10-111-4/+21
| | | | | | | | If the status of the player is "stop", we don't have a new song to handle. In this case, if there's a current song, let's update the status and clear our state. Closes #1.
* scrobbler: record how long a song was playedFranck Cuny2021-10-102-1/+16
| | | | | | | | Add a column `playtime` to the records table to keep track of how long a song was played. With this information, in the future, we will be able to sum up how long we listen to music, but also which songs were skipped.
* scrobbler: use helper function EqualAttrsFranck Cuny2021-10-101-3/+1
| | | | | | To compare the current attributes with the current record, we can use the helper `EqualAttrs` which will tell us if we need to create a new record or not.
* record: add some basic testingFranck Cuny2021-10-102-0/+59
|
* mpd-stats: pass database path to the scrobblerFranck Cuny2021-10-101-4/+27
| | | | | | | | When creating a scrobbler, we provide the path to the database. The scrobbler then get a handler to the database. When a new record is created, we persist it to the database using the `save` function.
* scrobbler: add timestamp to the recordFranck Cuny2021-10-101-9/+11
| | | | When we create a new record, let's capture when this was created.
* scrobbler: add interface to the sqlite3 databaseFranck Cuny2021-10-101-0/+54
| | | | | | | | | We want to persist the records in a database, so we can extract statistics and an history. The module for the database is straightforward: it opens the database if it exists and return an handler to it. If the database does not exists, we create it and we create the only table we need (records).
* scrobbler: add functions to create and run itFranck Cuny2021-10-101-0/+66
| | | | | | | | | | | | Add a new function to create a scrobbler. The function takes care of creating the mpd client. Add a function to run the scrobbler, which takes care of creating a new record when needed. This will simplify the interface for the caller, as all they really care about is: create the scrobbler, close it when we're done, and collect songs information while we listen to our music.
* mpd: export the type PlayerFranck Cuny2021-10-101-4/+4
|
* mpd: add function `Close` to the playerFranck Cuny2021-10-101-0/+10
| | | | | Let's close both the watcher and the client, instead of leaking this interface to the user.
* mpd: rename function to create the playerFranck Cuny2021-10-101-1/+1
|
* scrobbler: initial log record typeFranck Cuny2021-10-091-0/+34
| | | | | Define the type for a log record and add an helper function to create a new record.
* scrobbler: watch for events and print song detailsFranck Cuny2021-10-091-0/+38
We create a module "mpd" to interact with our MPD instance. For now we only have a single function to create a new client, which creates an actual client for mpd (and we ping the instance every 30 seconds), and a watcher to receive new events. The tool "scrobbler" then wait for new events and display songs information.