1
0
mirror of https://github.com/kellyjonbrazil/jc.git synced 2025-06-17 00:07:37 +02:00
Files
jc/docs/parsers/http_headers.md
Kelly Brazil f50f96381d doc update
2024-02-06 01:54:31 +00:00

7.7 KiB

Home

jc.parsers.http_headers

jc - JSON Convert HTTP headers parser

Converts HTTP request and response headers into a list of dictionaries. Well-known headers are processed to allow multiple instances which are aggregated into an array along with any comma-separated values. Integer, float, and datetimes are converted where defined in the specifications.

https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers https://datatracker.ietf.org/doc/html/rfc2616 https://datatracker.ietf.org/doc/html/rfc3229 https://datatracker.ietf.org/doc/html/rfc7089 https://datatracker.ietf.org/doc/html/rfc7231 https://datatracker.ietf.org/doc/html/rfc5789

If you are converting HTTP headers from curl verbose output, use the curl-head parser which will strip the > and < characters and remove non-header lines that begin with *.

Usage (cli):

$ cat headers.txt | jc --http-headers

Usage (module):

import jc
result = jc.parse('http_headers', http_headers_output)

Schema:

[
  {
    "<header>":                             string,
    "accept": [
                                            string
    ],
    "accept-ch": [
                                            string
    ],
    "accept-ch-lifetime":                   integer,
    "accept-encoding": [
                                            string
    ],
    "accept-language": [
                                            string
    ],
    "accept-patch": [
                                            string
    ],
    "accept-post": [
                                            string
    ],
    "accept-ranges": [
                                            string
    ],
    "access-control-allow-headers": [
                                            string
    ],
    "access-control-allow-methods": [
                                            string
    ],
    "access-control-expose-headers": [
                                            string
    ],
    "access-control-max-age":               integer,
    "access-control-request-headers": [
                                            string
    ],
    "age":                                  integer,
    "allow": [
                                            string
    ],
    "alt-svc": [
                                            string
    ],
    "cache-control": [
                                            string
    ],
    "clear-site-data": [
                                            string
    ],
    "connection": [
                                            string
    ],
    "content-encoding": [
                                            string
    ],
    "content-dpr":                          integer,
    "content-language": [
                                            string
    ],
    "content-length":                       integer,
    "content-security-policy": [
                                            string
    ],
    "content-security-policy-report-only": [
                                            string
    ],
    "cookie": [
                                            string
    ],
    "critical-ch": [
                                            string
    ],
    "date":                                 string,
    "date_epoch_utc":                       integer,
    "expect-ct": [
                                            string
    ],
    "expires":                              string,
    "expires_epoch_utc":                    integer,
    "device-memory":                        integer,
    "downlink":                             integer,
    "dpr":                                  integer,
    "forwarded": [
                                            string
    ],
    "if-match": [
                                            string
    ],
    "if-modified-since":                    string,
    "if-modified-since_epoch_utc":          integer,
    "if-none-match": [
                                            string
    ],
    "if-range":                             string,
    "if-range_epoch_utc":                   integer,
    "if-unmodified-since":                  string,
    "if-unmodified-since_epoch_utc":        integer,
    "im": [
                                            string
    ],
    "keep-alive": [
                                            string
    ],
    "large-allocation":                     integer,
    "last-modified":                        string,
    "last-modified_epoch_utc":              integer,
    "link": [
                                            string
    ],
    "max-forwards":                         integer,
    "memento-datetime":                     string,
    "memento-datetime_epoch_utc":           integer,
    "permissions-policy": [
                                            string
    ],
    "pragma": [
                                            string
    ],
    "proxy-authenticate": [
                                            string
    ],
    "retry-after":                          string,
    "retry-after_epoch_utc":                integer,
    "rtt":                                  integer,
    "sec-ch-ua": [
                                            string
    ],
    "sec-ch-ua-full-version-list": [
                                            string
    ],
    "server": [
                                            string
    ],
    "server-timing": [
                                            string
    ],
    "set-cookie": [
                                            string
    ],
    "timing-allow-origin": [
                                            string
    ],
    "trailer": [
                                            string
    ],
    "transfer-encoding": [
                                            string
    ],
    "upgrade": [
                                            string
    ],
    "upgrade-insecure-requests":            integer,
    "vary": [
                                            string
    ],
    "via": [
                                            string
    ],
    "warning": [
                                            string
    ],
    "www-authenticate": [
                                            string
    ],
    "x-cache-hits": [
                                            integer
    ],
    "x-content-duration":                   float
  }
]

Examples:

$ curl-head | jc --curl-head -p
[]

$ curl-head | jc --curl-head -p -r
[]

parse

def parse(data: str,
          raw: bool = False,
          quiet: bool = False) -> List[JSONDictType]

Main text parsing function

Parameters:

data:        (string)  text data to parse
raw:         (boolean) unprocessed output if True
quiet:       (boolean) suppress warning messages if True

Returns:

List of Dictionaries. Raw or processed structured data.

Parser Information

Compatibility: linux, darwin, cygwin, win32, aix, freebsd

Source: jc/parsers/http_headers.py

Version 1.0 by Kelly Brazil (kellyjonbrazil@gmail.com)