From 51da99365959f4fd35cef7b5f8f919386f2cf4ca Mon Sep 17 00:00:00 2001 From: bptato Date: Sat, 1 Jul 2023 23:31:39 +0200 Subject: Factor out headers into separate module --- src/io/headers.nim | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 src/io/headers.nim (limited to 'src/io/headers.nim') diff --git a/src/io/headers.nim b/src/io/headers.nim new file mode 100644 index 00000000..3bc3659b --- /dev/null +++ b/src/io/headers.nim @@ -0,0 +1,64 @@ +import tables + +import js/javascript +import utils/twtstr + +type Headers* = ref object + table* {.jsget.}: Table[string, seq[string]] + +jsDestructor(Headers) + +proc fill*(headers: Headers, ctx: JSContext, val: JSValue) = + if isSequence(ctx, val): + let x = fromJS[seq[(string, string)]](ctx, val) + if x.isSome: + for (k, v) in x.get: + if k in headers.table: + headers.table[k].add(v) + else: + headers.table[k] = @[v] + else: + let x = fromJS[Table[string, string]](ctx, val) + if x.isSome: + for k, v in x.get: + if k in headers.table: + headers.table[k].add(v) + else: + headers.table[k] = @[v] + +func newHeaders*(): Headers = + new(result) + +func newHeaders*(ctx: JSContext, obj = none(JSValue)): Headers {.jsctor.} = + new(result) + if obj.isSome: + result.fill(ctx, obj.get) + +func newHeaders*(table: Table[string, string]): Headers = + new(result) + for k, v in table: + let k = k.toHeaderCase() + if k in result.table: + result.table[k].add(v) + else: + result.table[k] = @[v] + +proc add*(headers: var Headers, k, v: string) = + let k = k.toHeaderCase() + if k notin headers.table: + headers.table[k] = @[v] + else: + headers.table[k].add(v) + +proc `[]=`*(headers: var Headers, k, v: string) = + headers.table[k.toHeaderCase()] = @[v] + +func getOrDefault*(headers: Headers, k: string, default = ""): string = + let k = k.toHeaderCase() + if k in headers.table: + headers.table[k][0] + else: + default + +proc addHeadersModule*(ctx: JSContext) = + ctx.registerType(Headers) -- cgit 1.4.1-2-gfad0