package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-0.1.4.tbz
sha256=49fe887d05083b37523cd6e7ca35239822c561fe7109dd383c30aeb4259a7b98
sha512=4135ad42a75fb9adc3e853a466b696d9ee6d7a9d8acf0cee9fd5f5485679a517f524ce704e2d153df4a7c4f1d14df9f94ab2a8fbe5b36e744b505daab1d40f3d
doc/src/sihl.user/user_password_reset_service.ml.html
Source file user_password_reset_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 56 57 58 59 60 61 62
open Base open Lwt.Syntax module Sig = User_password_reset_service_sig let kind = "password_reset" module TokenData = struct type t = { user_id : string } [@@deriving yojson, make, fields] end module Make (Log : Log.Service.Sig.SERVICE) (TokenService : Token.Service.Sig.SERVICE) (UserService : User_service_sig.SERVICE) : Sig.SERVICE = struct let create_reset_token ctx ~email = let* user = UserService.find_by_email_opt ctx ~email in match user with | Some user -> let user_id = User_core.User.id user in let data = TokenData.make ~user_id |> TokenData.to_yojson |> Yojson.Safe.to_string in let* token = TokenService.create ctx ~kind ~data ~expires_in:Utils.Time.OneDay () in Lwt.return @@ Some token | None -> Log.warn (fun m -> m "PASSWORD_RESET: No user found with email %s" email); Lwt.return None let reset_password ctx ~token ~password ~password_confirmation = let* token = TokenService.find_opt ctx token in let token = Result.of_option ~error:"Invalid or expired token provided" token in let user_id = token |> Result.map ~f:Token.data |> Result.bind ~f:(Result.of_option ~error:"Token has not user assigned") |> Result.bind ~f:Utils.Json.parse |> Result.bind ~f:TokenData.of_yojson |> Result.map ~f:TokenData.user_id in match user_id with | Error msg -> Lwt.return @@ Error msg | Ok user_id -> let* user = UserService.find ctx ~user_id in let* result = UserService.set_password ctx ~user ~password ~password_confirmation () in Lwt.return @@ Result.map ~f:(fun _ -> ()) result let start ctx = Lwt.return ctx let stop _ = Lwt.return () let lifecycle = Core.Container.Lifecycle.make "password-reset" ~start ~stop ~dependencies: [ Log.lifecycle; TokenService.lifecycle; UserService.lifecycle ] end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>