about summary refs log tree commit diff
path: root/pkgs/data/documentation/nginx-doc/default.nix
blob: c367912d6f98234bf5d86b552384c52d6baca457 (plain) (blame)
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
{ lib, stdenv, libxml2, libxslt, fetchhg }:

# Upstream maintains documentation (sources of https://nginx.org) in separate
# mercurial repository, which do not correspond to particular git commit, but at
# least has "introduced in version X.Y" comments.
#
# In other words, documentation does not necessary matches capabilities of
# $out/bin/nginx, but we have no better options.
stdenv.mkDerivation {
  pname = "nginx-doc-unstable";
  version = "2022-05-05";
  src = fetchhg {
    url = "https://hg.nginx.org/nginx.org";
    rev = "a3aee2697d4e";
    sha256 = "029n4mnmjw94h01qalmjgf1c2h3h7wm798xv5knk3padxiy4m28b";
  };
  patches = [ ./exclude-google-analytics.patch ];
  nativeBuildInputs = [ libxslt libxml2 ];

  # Generated documentation is not local-friendly, since it assumes that link to directory
  # is the same as link to index.html in that directory, which is not how browsers behave
  # with local filesystem.
  #
  # TODO: patch all relative links that do not end with .html.

  # /en subdirectory must exist, relative links expect it.
  installPhase = ''
    mkdir -p $out/share/doc/nginx
    mv libxslt/en $out/share/doc/nginx
  '';

  meta = with lib; {
    description = "A reverse proxy and lightweight webserver (documentation)";
    homepage    = "https://nginx.org/";
    license     = licenses.bsd2;
    platforms   = platforms.all;
    priority    = 6;
    maintainers = with maintainers; [ kaction ];
  };
}