package caqti

  1. Overview
  2. Docs

Source file caqti_connect_sig.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
(* Copyright (C) 2017--2018  Petter A. Urkedal <paurkedal@gmail.com>
 *
 * This library is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or (at your
 * option) any later version, with the OCaml static compilation exception.
 *
 * This library is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
 * License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this library.  If not, see <http://www.gnu.org/licenses/>.
 *)

(** Signature for establishing database connections. *)

module type S = sig

  type 'a future
  (** The type of a deferred value of type ['a]. *)

  module Pool : Caqti_pool_sig.S with type 'a future := 'a future
  (** A pool implementation for the current concurrency library. *)

  module type CONNECTION =
    Caqti_connection_sig.S with type 'a future := 'a future
  (** The connection API specialized for the current concurrency library. *)

  type connection = (module CONNECTION)
  (** Shortcut for the connection API passed as a value. *)

  val connect : Uri.t ->
    (connection, [> Caqti_error.load_or_connect]) result future
  (** [connect uri] locates and loads a driver which can handle [uri], passes
      [uri] to the driver, which establish a connection and returns a
      first-class module implementing {!Caqti_connection_sig.S}. *)

  val connect_pool : ?max_size: int -> Uri.t ->
    ((connection, [> Caqti_error.connect]) Pool.t, [> Caqti_error.load]) result
  (** [connect_pool uri] is a pool of database connections constructed by
      [connect uri]. *)
end
OCaml

Innovation. Community. Security.