about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--doc/config.md10
-rw-r--r--src/config/config.nim16
-rw-r--r--src/loader/loader.nim33
-rw-r--r--src/loader/request.nim4
-rw-r--r--src/local/pager.nim26
5 files changed, 41 insertions, 48 deletions
diff --git a/doc/config.md b/doc/config.md
index 3be07c81..5d584f37 100644
--- a/doc/config.md
+++ b/doc/config.md
@@ -335,7 +335,9 @@ supported by cURL may be used. Can be overridden by siteconf.</td>
 <tr>
 <td>default-headers</td>
 <td>Table</td>
-<td>Specify a list of default headers for all HTTP(S) network requests.</td>
+<td>Specify a list of default headers for all HTTP(S) network requests. Can be
+overridden by siteconf.</td>
+</tr>
 
 </table>
 
@@ -649,6 +651,12 @@ with this stylesheet to get the final user stylesheet.)</td>
 <td>Specify a proxy for network requests fetching contents of this buffer.</td>
 </tr>
 
+<tr>
+<td>default-headers</td>
+<td>Table</td>
+<td>Specify a list of default headers for HTTP(S) network requests to this
+buffer.</td>
+</tr>
 
 </table>
 
diff --git a/src/config/config.nim b/src/config/config.nim
index 432f5875..a01187a7 100644
--- a/src/config/config.nim
+++ b/src/config/config.nim
@@ -47,6 +47,7 @@ type
     images*: Opt[bool]
     stylesheet*: Opt[string]
     proxy*: Opt[URL]
+    default_headers*: Opt[Table[string, string]]
 
   OmniRule* = object
     match*: Regex
@@ -87,7 +88,7 @@ type
     max_redirect* {.jsgetset.}: int32
     prepend_https* {.jsgetset.}: bool
     prepend_scheme* {.jsgetset.}: string
-    proxy* {.jsgetset.}: Opt[string]
+    proxy* {.jsgetset.}: URL
     default_headers* {.jsgetset.}: Table[string, string]
 
   DisplayConfig = object
@@ -249,19 +250,6 @@ proc bindLineKey(config: Config; key, action: string) {.jsfunc.} =
 proc hasprop(a: ptr ActionMap; s: string): bool {.jshasprop.} =
   return s in a[]
 
-func getProxy*(config: Config): URL =
-  if config.network.proxy.isSome:
-    let s = config.network.proxy.get
-    let x = parseURL(s)
-    if x.isSome:
-      return x.get
-    else:
-      raise newException(ValueError, "Invalid proxy URL: " & s)
-  return nil
-
-func getDefaultHeaders*(config: Config): Headers =
-  return newHeaders(config.network.default_headers)
-
 proc openFileExpand(dir, file: string): FileStream =
   if file.len == 0:
     return nil
diff --git a/src/loader/loader.nim b/src/loader/loader.nim
index 6cc37b71..9c9c2e8a 100644
--- a/src/loader/loader.nim
+++ b/src/loader/loader.nim
@@ -429,6 +429,21 @@ proc loadResource(ctx: LoaderContext; client: ClientData; request: Request;
   if tries >= MaxRewrites:
     handle.rejectHandle(ERROR_TOO_MANY_REWRITES)
 
+proc setupRequestDefaults*(request: Request; config: LoaderClientConfig) =
+  request.defaultHeadersSet = true
+  for k, v in config.defaultHeaders.table:
+    if k notin request.headers.table:
+      request.headers.table[k] = v
+  if config.cookieJar != nil and config.cookieJar.cookies.len > 0:
+    if "Cookie" notin request.headers.table:
+      let cookie = config.cookieJar.serialize(request.url)
+      if cookie != "":
+        request.headers["Cookie"] = cookie
+  if request.referrer != nil and "Referer" notin request.headers:
+    let r = request.referrer.getReferrer(request.url, config.referrerPolicy)
+    if r != "":
+      request.headers["Referer"] = r
+
 proc onLoad(ctx: LoaderContext; stream: SocketStream; client: ClientData) =
   var request: Request
   stream.sread(request)
@@ -440,20 +455,10 @@ proc onLoad(ctx: LoaderContext; stream: SocketStream; client: ClientData) =
   if not client.config.filter.match(request.url):
     handle.rejectHandle(ERROR_DISALLOWED_URL)
   else:
-    for k, v in client.config.defaultHeaders.table:
-      if k notin request.headers.table:
-        request.headers.table[k] = v
-    let cookieJar = client.config.cookieJar
-    if cookieJar != nil and cookieJar.cookies.len > 0:
-      if "Cookie" notin request.headers.table:
-        let cookie = cookieJar.serialize(request.url)
-        if cookie != "":
-          request.headers["Cookie"] = cookie
-    if request.referrer != nil and "Referer" notin request.headers:
-      let r = request.referrer.getReferrer(request.url,
-        client.config.referrerPolicy)
-      if r != "":
-        request.headers["Referer"] = r
+    if ctx.pagerClient != client or not request.defaultHeadersSet:
+      # do not override defaults for pager, because it starts requests that
+      # later belong to buffers.
+      request.setupRequestDefaults(client.config)
     if request.proxy == nil or not client.config.acceptProxy:
       request.proxy = client.config.proxy
     ctx.loadResource(client, request, handle)
diff --git a/src/loader/request.nim b/src/loader/request.nim
index 05b02114..60632041 100644
--- a/src/loader/request.nim
+++ b/src/loader/request.nim
@@ -81,6 +81,10 @@ type
     # when set to true, the loader will not write data from the body (not
     # headers!) into the output until a resume is received.
     suspended*: bool
+    # if defaultHeadersSet is set, then loader will not set default headers
+    # for the request if it was received from the pager. (this is used when
+    # starting requests for new buffers.)
+    defaultHeadersSet*: bool
 
 jsDestructor(Request)
 
diff --git a/src/local/pager.nim b/src/local/pager.nim
index 31652817..b8041236 100644
--- a/src/local/pager.nim
+++ b/src/local/pager.nim
@@ -40,7 +40,6 @@ import types/cell
 import types/color
 import types/cookie
 import types/opt
-import types/referrer
 import types/url
 import types/winattrs
 import utils/strwidth
@@ -123,7 +122,6 @@ type
     numload*: int # number of pages currently being loaded
     precnum*: int32 # current number prefix (when vi-numeric-prefix is true)
     procmap*: seq[ProcMapItem]
-    proxy: URL
     redraw: bool
     regex: Opt[Regex]
     reverseSearch: bool
@@ -276,7 +274,6 @@ proc newPager*(config: Config; forkserver: ForkServer; ctx: JSContext;
   return Pager(
     config: config,
     forkserver: forkserver,
-    proxy: config.getProxy(),
     term: newTerminal(stdout, config),
     alerts: alerts
   )
@@ -298,8 +295,8 @@ proc setLoader*(pager: Pager, loader: FileLoader) =
   pager.devRandom = newPosixStream("/dev/urandom", O_RDONLY, 0)
   pager.loader = loader
   let config = LoaderClientConfig(
-    defaultHeaders: pager.config.getDefaultHeaders(),
-    proxy: pager.config.getProxy(),
+    defaultHeaders: newHeaders(pager.config.network.default_headers),
+    proxy: pager.config.network.proxy,
     filter: newURLFilter(default = true),
   )
   loader.key = pager.addLoaderClient(pager.loader.clientPid, config)
@@ -506,18 +503,7 @@ proc newContainer(pager: Pager; bufferConfig: BufferConfig;
     contentType = none(string); charsetStack: seq[Charset] = @[];
     url = request.url; cacheId = -1; cacheFile = ""): Container =
   request.suspended = true
-  if loaderConfig.cookieJar != nil:
-    # loader stores cookie jars per client, but we have no client yet.
-    # therefore we must set cookie here
-    let cookie = loaderConfig.cookieJar.serialize(request.url)
-    if cookie != "":
-      request.headers["Cookie"] = cookie
-  if request.referrer != nil:
-    # same with referrer
-    let r = request.referrer.getReferrer(request.url,
-      loaderConfig.referrerPolicy)
-    if r != "":
-      request.headers["Referer"] = r
+  request.setupRequestDefaults(loaderConfig)
   let stream = pager.loader.startRequest(request)
   pager.loader.registerFun(stream.fd)
   let container = newContainer(
@@ -884,12 +870,12 @@ proc applySiteconf(pager: Pager; url: var URL; charsetOverride: Charset;
   let host = url.host
   var referer_from = false
   var cookieJar: CookieJar = nil
-  var headers = pager.config.getDefaultHeaders()
+  var headers = newHeaders(pager.config.network.default_headers)
   var scripting = false
   var images = false
   var charsets = pager.config.encoding.document_charset
   var userstyle = pager.config.css.stylesheet
-  var proxy = pager.proxy
+  var proxy = pager.config.network.proxy
   for sc in pager.config.siteconf:
     if sc.url.isSome and not sc.url.get.match($url):
       continue
@@ -922,6 +908,8 @@ proc applySiteconf(pager: Pager; url: var URL; charsetOverride: Charset;
       userstyle &= sc.stylesheet.get
     if sc.proxy.isSome:
       proxy = sc.proxy.get
+    if sc.default_headers.isSome:
+      headers = newHeaders(sc.default_headers.get)
   loaderConfig = LoaderClientConfig(
     defaultHeaders: headers,
     cookiejar: cookieJar,