2
0
Fork 0
mirror of git://git.savannah.gnu.org/guix/guix-cuirass.git synced 2023-12-14 06:03:04 +01:00
guix-cuirass/src/cuirass/notification.scm
2021-03-11 10:27:13 +01:00

171 lines
4.9 KiB
Scheme
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

;;; notification.scm -- Send build notifications.
;;; Copyright © 2021 Mathieu Othacehe <othacehe@gnu.org>
;;;
;;; This file is part of Cuirass.
;;;
;;; GNU Guix is free software; you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3 of the License, or (at
;;; your option) any later version.
;;;
;;; GNU Guix is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
(define-module (cuirass notification)
#:use-module (cuirass database)
#:use-module (cuirass logging)
#:use-module (cuirass mail)
#:use-module (cuirass mastodon)
#:use-module (cuirass parameters)
#:use-module (cuirass utils)
#:use-module (guix build syscalls)
#:use-module (guix records)
#:use-module (ice-9 match)
#:use-module (ice-9 threads)
#:export (email
email?
email-from
email-to
email-server
mastodon
mastodon?
notification->sexp
sexp->notification
start-notification-thread))
;;;
;;; Notification types.
;;;
(define-record-type* <email>
email make-email
email?
(from email-from) ;string
(to email-to) ;string
(server email-server)) ;string
(define-record-type* <mastodon>
mastodon make-mastodon
mastodon?)
(define (notification->sexp notif)
"Return an sexp describing NOTIF."
(cond
((email? notif)
`(email
(from ,(email-from notif))
(to ,(email-to notif))
(server ,(email-server notif))))
((mastodon? notif)
'(mastodon))))
(define (sexp->notification sexp)
"Return the notification corresponding to SEXP."
(match sexp
(('email ('from from)
('to to)
('server server))
(email
(from from)
(to to)
(server server)))
(('mastodon)
(mastodon))))
;;;
;;; Send notifications.
;;;
;; XXX: Some redefinitions to avoid a circular dependency with the (cuirass
;; database) module.
(define weather-success 0)
(define weather-failure 1)
(define (build-weather-text build)
"Return the build weather string."
(let ((weather (assq-ref build #:weather)))
(cond
((= weather weather-success)
"fixed")
((= weather weather-failure)
"broken"))))
(define (build-details-url build)
"Return the build details URL for BUILD."
(let ((id (assq-ref build #:id))
(url (or (%cuirass-url) "")))
(string-append url "/build/" (number->string id) "/details")))
(define (notification-subject build)
"Return the subject for the given NOTIFICATION."
(let* ((job-name (assq-ref build #:job-name))
(specification (assq-ref build #:specification))
(weather-text (build-weather-text build)))
(format #f "Build ~a on ~a is ~a."
job-name specification weather-text)))
(define (notification-text build)
"Return the text for the given NOTIFICATION."
(let* ((url (build-details-url build))
(job-name (assq-ref build #:job-name))
(specification (assq-ref build #:specification))
(weather-text (build-weather-text build)))
(format #f "The build ~a for specification ~a is ~a. You can find \
the detailed information about this build here: ~a."
job-name specification weather-text url)))
(define (send-email* notif build)
"Send an email for the given NOTIFICATION."
(let* ((from (email-from notif))
(to (email-to notif))
(server (email-server notif))
(subject (notification-subject build))
(text (notification-text build)))
(catch #t
(lambda ()
(send-email server
#:from from
#:to to
#:subject subject
#:text text))
(lambda args
(log-message "Failed to send the email notification: ~a."
args)))))
(define (send-mastodon build)
"Send a new status for the given NOTIFICATION."
(let ((text (notification-text build)))
(catch #t
(lambda ()
(send-status text))
(lambda args
(log-message "Failed to send the mastodon notification: ~a."
args)))))
(define (start-notification-thread)
"Start a thread sending build notifications."
(call-with-new-thread
(lambda ()
(set-thread-name "notification")
(let loop ()
(match (db-pop-notification)
((notif . build)
(cond
((email? notif)
(send-email* notif build))
((mastodon? notif)
(send-mastodon build))))
(#f #f))
(sleep 1)
(loop)))))