package sihl

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file service.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
module Core = Sihl_core
open Lwt.Syntax

let log_src = Logs.Src.create ~doc:"schedule" "sihl.service.schedule"

module Logs = (val Logs.src_log log_src : Logs.LOG)

let registered_schedules : Model.t list ref = ref []

let schedule schedule =
  let should_stop = ref false in
  let stop_schedule () = should_stop := true in
  Logs.debug (fun m -> m "SCHEDULE: Scheduling %s" (Model.label schedule));
  let scheduled_function = Model.scheduled_function schedule in
  let rec loop () =
    let now = Ptime_clock.now () in
    let duration = Model.run_in schedule ~now in
    Logs.debug (fun m ->
        m "SCHEDULE: Running schedule %s in %f seconds" (Model.label schedule) duration);
    let* () =
      Lwt.catch
        (fun () -> scheduled_function ())
        (fun exn ->
          Logs.err (fun m ->
              m
                "Exception caught while running schedule, this is a bug in your \
                 scheduled function. %s"
                (Printexc.to_string exn));
          Lwt.return ())
    in
    let* () = Lwt_unix.sleep duration in
    if !should_stop
    then (
      let () =
        Logs.debug (fun m -> m "SCHEDULE: Stop schedule %s" (Model.label schedule))
      in
      Lwt.return ())
    else loop ()
  in
  loop () |> ignore;
  stop_schedule
;;

let start ctx =
  List.iter (fun s -> schedule s ()) !registered_schedules;
  Lwt.return ctx
;;

let stop _ = Lwt.return ()
let lifecycle = Core.Container.Lifecycle.create "schedule" ~start ~stop

let register ?(schedules = []) () =
  registered_schedules := schedules;
  Core.Container.Service.create lifecycle
;;
OCaml

Innovation. Community. Security.