package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-queue-0.1.10.tbz
sha256=b264f357c2a65dbed00c3459be76cdd9b21275aeb9d0289634a2050161665211
sha512=b22fa96a3c7fa607df04848b40a0f54890f4f63c519d10ff7fcef8ccf09341731b42ff4decccb4a7e858e138a803c849ee0c5226c514938cdcded2fd80cae4cb
doc/src/sihl.migration/repo.ml.html
Source file repo.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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
module Database = Sihl_database module MariaDb : Sig.REPO = struct let create_request = Caqti_request.exec Caqti_type.unit {sql| CREATE TABLE IF NOT EXISTS core_migration_state ( namespace VARCHAR(128) NOT NULL, version INTEGER, dirty BOOL NOT NULL, PRIMARY KEY (namespace) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci; |sql} ;; let create_table_if_not_exists () = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.exec create_request () |> Lwt.map Database.Service.raise_error) ;; let get_request = Caqti_request.find_opt Caqti_type.string Caqti_type.(tup3 string int bool) {sql| SELECT namespace, version, dirty FROM core_migration_state WHERE namespace = ?; |sql} ;; let get ~namespace = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.find_opt get_request namespace |> Lwt.map Database.Service.raise_error) |> Lwt.map (Option.map Model.of_tuple) ;; let upsert_request = Caqti_request.exec Caqti_type.(tup3 string int bool) {sql| INSERT INTO core_migration_state ( namespace, version, dirty ) VALUES ( ?, ?, ? ) ON DUPLICATE KEY UPDATE version = VALUES(version), dirty = VALUES(dirty) |sql} ;; let upsert ~state = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.exec upsert_request (Model.to_tuple state) |> Lwt.map Database.Service.raise_error) ;; end module PostgreSql : Sig.REPO = struct let create_request = Caqti_request.exec Caqti_type.unit {sql| CREATE TABLE IF NOT EXISTS core_migration_state ( namespace VARCHAR(128) NOT NULL PRIMARY KEY, version INTEGER, dirty BOOL NOT NULL ); |sql} ;; let create_table_if_not_exists () = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.exec create_request () |> Lwt.map Database.Service.raise_error) ;; let get_request = Caqti_request.find_opt Caqti_type.string Caqti_type.(tup3 string int bool) {sql| SELECT namespace, version, dirty FROM core_migration_state WHERE namespace = ?; |sql} ;; let get ~namespace = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.find_opt get_request namespace |> Lwt.map Database.Service.raise_error) |> Lwt.map (Option.map Model.of_tuple) ;; let upsert_request = Caqti_request.exec Caqti_type.(tup3 string int bool) {sql| INSERT INTO core_migration_state ( namespace, version, dirty ) VALUES ( ?, ?, ? ) ON CONFLICT (namespace) DO UPDATE SET version = EXCLUDED.version, dirty = EXCLUDED.dirty |sql} ;; let upsert ~state = Database.Service.query (fun (module Connection : Caqti_lwt.CONNECTION) -> Connection.exec upsert_request (Model.to_tuple state) |> Lwt.map Database.Service.raise_error) ;; end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>