๐Ÿ“ฆ facebook / react-native

๐Ÿ“„ serve-static_v1.x.x.js ยท 122 lines
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/**
 * Copyright (c) Meta Platforms, Inc. and affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 *
 * @flow strict
 * @format
 */

declare module 'serve-static' {
  import type {NextHandleFunction} from 'connect';
  import type http from 'http';

  declare export type Options = Readonly<{
    /**
     * Enable or disable accepting ranged requests, defaults to true. Disabling
     * this will not send `Accept-Ranges` and ignore the contents of the
     * `Range` request header.
     */
    acceptRanges?: boolean,

    /**
     * Enable or disable setting `Cache-Control` response header, defaults to
     * true. Disabling this will ignore the `immutable` and `maxAge` options.
     */
    cacheControl?: boolean,

    /**
     * Set how "dotfiles" are treated when encountered. A dotfile is a file or
     * directory that begins with a dot (".").
     *
     * Note this check is done on the path itself without checking if the path
     * actually exists on the disk. If `root` is specified, only the dotfiles
     * above the root are checked (i.e. the root itself can be within a dotfile
     * when when set to "deny").
     *
     * The default value is 'ignore'.
     *
     * 'allow' No special treatment for dotfiles
     * 'deny' Send a 403 for any request for a dotfile
     * 'ignore' Pretend like the dotfile does not exist and call next()
     */
    dotfiles?: string,

    /**
     * Enable or disable etag generation, defaults to true.
     */
    etag?: boolean,

    /**
     * Set file extension fallbacks. When set, if a file is not found, the
     * given extensions will be added to the file name and search for.
     * The first that exists will be served. Example: ['html', 'htm'].
     *
     * The default value is false.
     */
    extensions?: Array<string> | false,

    /**
     * Let client errors fall-through as unhandled requests, otherwise forward
     * a client error.
     *
     * The default value is true.
     */
    fallthrough?: boolean,

    /**
     * Enable or disable the immutable directive in the `Cache-Control` response
     * header.
     *
     * If enabled, the `maxAge` option should also be specified to enable
     * caching. The immutable directive will prevent supported clients from
     * making conditional requests during the life of the maxAge option to
     * check if the file has changed.
     */
    immutable?: boolean,

    /**
     * By default this module will send "index.html" files in response to a
     * request on a directory. To disable this set false or to supply a new
     * index pass a string or an array in preferred order.
     */
    index?: boolean | string | Array<string>,

    /**
     * Enable or disable `Last-Modified` header, defaults to true. Uses the file
     * system's last modified value.
     */
    lastModified?: boolean,

    /**
     * Provide a max-age in milliseconds for http caching, defaults to 0. This
     * can also be a string accepted by the `ms` module.
     */
    maxAge?: number | string,

    /**
     * Redirect to trailing "/" when the pathname is a dir. Defaults to true.
     */
    redirect?: boolean,

    /**
     * Function to set custom headers on response. Alterations to the headers
     * need to occur synchronously.
     *
     * The function is called as `fn(res, path, stat)`, where the arguments are:
     * `res` the response object
     * `path` the file path that is being sent
     * `stat` the stat object of the file that is being sent
     */
    setHeaders?: (res: http.ServerResponse, path: string, stat: any) => any,
  }>;

  declare type serveStatic = (
    root: string,
    options?: Options,
  ) => NextHandleFunction;

  declare module.exports: serveStatic;
}