lots of QOL improvements.
This commit is contained in:
29
src/clj/auto_ap/background/invoices.clj
Normal file
29
src/clj/auto_ap/background/invoices.clj
Normal file
@@ -0,0 +1,29 @@
|
||||
(ns auto-ap.background.invoices
|
||||
(:require [auto-ap.datomic.invoices :as d-invoices]
|
||||
[auto-ap.datomic :refer [uri]]
|
||||
[datomic.api :as d]
|
||||
[auto-ap.time :as time]
|
||||
[clj-time.coerce :as coerce]))
|
||||
|
||||
(def break (atom false))
|
||||
|
||||
(defn close-auto-invoices []
|
||||
(while (and (not @break)
|
||||
(not (Thread/interrupted)))
|
||||
(println "Clearing automatic invoices")
|
||||
(try
|
||||
(->> (d/query {:query {:find ['?e]
|
||||
:in ['$ '?today]
|
||||
:where ['[?e :invoice/automatically-paid-when-due true]
|
||||
'[?e :invoice/status :invoice-status/unpaid]
|
||||
'[?e :invoice/due ?d]
|
||||
'[(<= ?d ?today)]]}
|
||||
:args [(d/db (d/connect uri)) (coerce/to-date (time/local-now))]})
|
||||
(mapv (fn [[i]] {:db/id i
|
||||
:invoice/outstanding-balance 0.0
|
||||
:invoice/status :invoice-status/paid}))
|
||||
(d/transact (d/connect uri))
|
||||
deref)
|
||||
(Thread/sleep (* 1000 60 60))
|
||||
(catch Exception e
|
||||
(println (.toString e))))))
|
||||
Reference in New Issue
Block a user