package sihl-queue
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=d1502bb2a31114e33f539910bfce1139
    
    
  sha512=6f5b4d1c6e6eb7c77fb483ef52eea5f69b75079830ec622a552fef33c4fe87f6a70499db9621a8fa298a80aa21649e0047aaba1b9eb53d28c2d573e1f84acf92
    
    
  doc/index.html
Sihl Queue
Queues are useful for running jobs in the background. Typical use cases are exporting tables as CSV files or sending emails over SMTP that take too long to perform during an HTTP request.
In essence, you create a job and register it with a job worker. In your app, use Sihl.Contract.Queue.Sig.dispatch to put the job onto a queue for later processing.
Backends
sihl-queue ships with 3 backend implementations.
Installation
Backend
First, choose a backend in service/service.ml:
module Queue = Sihl_queue.PostgreSqlRegistration
Register the service in run/run.ml:
let services = [ Service.Queue.register ~jobs:[] () ]Migrations
Run make sihl migrate to run pending migrations.
Usage
The service API is documented in Sihl.Contract.Queue.Sig.
Creating jobs
With Sihl_queue.create you can create a job in app/job/job.ml:
let cook_pizza =
  Sihl_queue.create
    (fun pizza_name ->
      Pizza.create_pizza pizza_name [] |> Lwt.map ignore |> Lwt.map Result.ok)
    "cook-pizza"
;;Don't forget to register the job with the queue service. The queue service comes with queue workers which need to know about the jobs available. In run.ml:
let services =
  [ Sihl.Database.register ()
  ; Service.Migration.(register ~migrations:Database.Migration.all ())
  ; Service.Queue.register ~jobs:[ Job.cook_pizza; Job.order_ingredient ] ()
  ]
;;Dispatching jobs
You can only dispatch jobs that have been registered.
Service.Queue.dispatch ~input:"funghi" cook_pizzaService.Queue.dispatch
  ~input:"funghi"
  ~delay:(Sihl.Time.Span.minutes 2)
  Job.cook_pizzaThe returned Lwt.t resolves as soon as the job is queued.
You can also dispatch multiple jobs of the same type with different inputs. Following dispatches the same job 3 times with different inputs.
Service.Queue.dispatch_all
  ~input:["funghi"; "salami"; "prosciutto"]
  ~delay:(Sihl.Time.Span.hours 1)
  Job.cook_pizzaDashboard
sihl-queue comes with a built-in dashboard. The dashboard is packaged as a router Sihl.Contract.Queue.Sig.router and can be mounted into any existing app.
In order to only allow authenticated users to use the dashboard you can add your custom authentication and authorization middlewares. In routes/site.ml:
let router_admin_queue =
  Service.Queue.router
    ~back:"/"
    ~prefix:"/path"
    "/admin/queue"In run.ml:
let services =
  [ Sihl.Database.register ()
  ; Service.Migration.(register ~migrations:Database.Migration.all ())
  ; Sihl.Web.Http.register
      ~middlewares:Routes.Global.middlewares
      ~routers:
        [ Routes.Api.router
        ; Routes.Site.router_admin_queue
        ]
      ()
  ; Service.Queue.register ~jobs:[ Job.cook_pizza; Job.order_ingredient ] ()
  ]
;;HTMX
The dashboard has built-in support for HTMX. However, it is not requird to use HTMX and the dahsboard remains usable without. HTMX is used for dynamic features like auto-refreshing parts of the job instance list.
In order to use HTMX set HTMX_SCRIPT_URL to the URL of the HTMX JavaScript file, either served by Sihl from public or by a CDN.