package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-0.1.4.tbz
sha256=49fe887d05083b37523cd6e7ca35239822c561fe7109dd383c30aeb4259a7b98
sha512=4135ad42a75fb9adc3e853a466b696d9ee6d7a9d8acf0cee9fd5f5485679a517f524ce704e2d153df4a7c4f1d14df9f94ab2a8fbe5b36e744b505daab1d40f3d
doc/sihl.cmd/Cmd/index.html
Module Cmd
Source
Use this module to create your own command line commands in order to interact with the Sihl app.
Services can register command with the command service. This is why a lot of services have a dependency on it. All the built-in commands are contributed by individual services using this mechanism. Examples for those commands are:
migrate
is registered by the migration service and it runs the migrationsstart
is registered by the web server service and it starts the web servercreateadmin
is registered by the user service and it creates an admin user, useful to bootstrap your app so you have one user to log in
You can contribute your custom commands the same way to interact with your app through the CLI. This can be very handy for development and administration. You sometimes want to call services without going through the HTTP stack, authentication, validation and authorization layers.
Source
val make :
name:Base.string ->
?help:Base.string ->
description:Base.string ->
fn:fn ->
unit ->
t
Usage
This is how the command createadmin
is implemented:
let create_admin_cmd =
Cmd.make ~name:"createadmin" ~help:"<username> <email> <password>"
~description:"Create an admin user"
~fn:(fun args ->
match args with
| [ username; email; password ] ->
let ctx = Core.Ctx.empty |> DbService.add_pool in
User_service.create_admin ctx ~email ~password ~username:(Some username)
|> Lwt_result.map ignore
| _ -> Lwt_result.fail "Usage: <username> <email> <password>")
()
let _ =
App.(empty
|> with_services services
|> with_commands [ create_admin_cmd ]
|> run)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page