summaryrefslogtreecommitdiff
path: root/lib/handlers.ml
blob: e7a76ce40861898334938d1a2a69d7657bf3c67c (plain)
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
(* -*- mode: tuareg; -*- *)

let root _req = Views.root ()

module Repo = struct
  let ( let* ) m f =
    Lwt.bind m @@ function
    | Ok x -> f x
    | Error e ->
        let msg = Format.asprintf "%a" Resolvers.Store.pp_error e in
        Views.error_page msg

  let summary req =
    let repo = Dream.param req "repo" in
    let* branches = Resolvers.Reference.all repo in
    let* commits = Resolvers.Commit.recent repo 10 in
    Views.Repo.summary repo branches commits

  let commits req =
    let repo = Dream.param req "repo" in
    let* commits = Resolvers.Commit.recent repo 100 in
    Views.Repo.commits repo commits

  let commit req =
    let repo = Dream.param req "repo" in
    let id = Dream.param req "id" in
    let* commit = Resolvers.Commit.of_id repo id in
    Views.Repo.commit repo commit

  let files_at_head req =
    let repo = Dream.param req "repo" in
    let* tree = Resolvers.Tree.head repo in
    Views.Repo.files repo tree

  let file_id req =
    let repo = Dream.param req "repo" in
    let id = Dream.param req "id" in
    let* res = Resolvers.blob_or_tree repo id in
    match res with
    | `Tree tree -> Views.Repo.files repo tree
    | `Blob blob -> Views.Repo.file repo blob

  let branches req =
    let repo = Dream.param req "repo" in
    let* branches = Resolvers.Reference.branches repo in
    Views.Repo.branches repo branches

  let tags req =
    let repo = Dream.param req "repo" in
    let* tags = Resolvers.Reference.tags repo in
    Views.Repo.tags repo tags

  let readme req =
    let repo = Dream.param req "repo" in
    let* readme = Resolvers.Repo.readme repo in
    match readme with
    | None ->
        let content = "README does not exist for " ^ repo in
        Views.Repo.file repo { content }
    | Some file -> Views.Repo.file repo file
end

let all_handlers =
  let open Dream in
  [
    get "/" root;
    scope "/:repo" []
      Repo.
        [
          get "/" summary;
          get "/summary/" summary;
          get "/commits/" commits;
          get "/commit/:id" commit;
          get "/files/" files_at_head;
          get "/file/:id" file_id;
          get "/branches/" branches;
          get "/tags/" tags;
          get "/README" readme;
        ];
    get "/static/**" (static "./lib/static");
  ]
Copyright 2019--2025 Marius PETER