X-Git-Url: http://git.vanrenterghem.biz/musicbrainz.git/blobdiff_plain/17f39bdf1ffe766e225cf8b8057468eb85c3fcd1..006cf0949378dc3f0c3368f0e2e29093ec67e4da:/listenbrainz.el diff --git a/listenbrainz.el b/listenbrainz.el index fc32c66..5ebf40a 100644 --- a/listenbrainz.el +++ b/listenbrainz.el @@ -2,9 +2,10 @@ ;; Copyright 2023 FoAM ;; -;; Author: nik gaffney +;; Author: nik gaffney , Frederik Vanrenterghem ;; Created: 2023-05-05 -;; Version: 0.1 +;; Updated: 2025-01-25 +;; Version: 0.2fv ;; Package-Requires: ((emacs "27.1") (request "0.3")) ;; Keywords: music, scrobbling, multimedia ;; URL: https://github.com/zzkt/listenbrainz @@ -262,7 +263,8 @@ macroexpands to something like -> :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Listens for user: %s" username))))))) + (message "Listens for user: %s\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-listens response)))) @@ -279,7 +281,8 @@ macroexpands to something like -> :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "User playing now: %s" username))))))) + (message "User playing now: %s\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-playing response)))) @@ -287,12 +290,13 @@ macroexpands to something like -> ;; - https://listenbrainz.readthedocs.io/en/production/dev/api-usage/#submitting-listens ;; - https://listenbrainz.readthedocs.io/en/production/dev/json/#json-doc -(defun listenbrainz-submit-listen (type artist track &optional release) +(defun listenbrainz-submit-listen (type artist track &optional release timestamp) "Submit listening data to ListenBrainz. - listen TYPE (string) either \='single\=', \='import\=' or \='playing_now\=' - ARTIST name (string) - TRACK title (string) -- RELEASE title (string) also album title." +- RELEASE title (string) also album title. +- TIMESTAMP time (time) track was listened to" (message "listenbrainz: submitting %s - %s - %s" artist track release) (let* ((json-null "") (now (listenbrainz-timestamp)) @@ -304,6 +308,7 @@ macroexpands to something like -> (remove nil (list (when (string= type "single") (cons "listened_at" now)) + (when (string= type "import") (cons "listened_at" (listenbrainz-timestamp timestamp))) (list "track_metadata" (cons "artist_name" artist) (cons "track_name" track) @@ -330,6 +335,10 @@ macroexpands to something like -> "Submit data for track (ARTIST TRACK and optional RELEASE) playing now." (listenbrainz-submit-listen "playing_now" artist track (when release release))) +;;;###autoload +(defun listenbrainz-submit-historic-listen (artist track timestamp &optional release) + "Submit data for track (ARTIST TRACK and optional RELEASE) heard at TIMESTAMP." + (listenbrainz-submit-listen "import" artist track (if release release "") timestamp)) ;;; ;; ;; ; ; ; ; ; ; ;; @@ -358,7 +367,8 @@ possible values are week, month, year, all_time, defaults to all_time." :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Top recordings for user: %s" username))))))) + (message "Top recordings for user: %s\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-stats-2 response)))) @@ -381,7 +391,8 @@ possible values are week, month, year, all_time, defaults to all_time." :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Top releases for user: %s" username))))))) + (message "Top releases for user: %s\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-stats-0 response)))) @@ -404,7 +415,8 @@ possible values are week, month, year, all_time, defaults to all_time." :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Top artists for user: %s" username))))))) + (message "Top artists for user: %s\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-stats-1 response)))) @@ -430,10 +442,11 @@ OUTPUT format can be either `list' (default) or `graph'." :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Followers for %s" username))))))) + (message "Followers for %s\n%s" username + (if data data "")))))))) (if (string= "graph" output) - (princ (listenbrainz--format-followers-graph response)) - (princ (listenbrainz--format-followers-list response))))) + (princ (listenbrainz--format-followers-graph response)) + (princ (listenbrainz--format-followers-list response))))) ;;;###autoload (defun listenbrainz-following (username) @@ -448,7 +461,8 @@ OUTPUT format can be either `list' (default) or `graph'." :sync t :success (cl-function (lambda (&key data &allow-other-keys) - (message "Users %s is following" username))))))) + (message "Users %s is following\n%s" username + (if data data "")))))))) (princ (listenbrainz--format-following response))))