From 78c39ef5b92a20501389a8a5aa235e3d5c65068c Mon Sep 17 00:00:00 2001 From: JSCU-CNI <121175071+JSCU-CNI@users.noreply.github.com> Date: Wed, 25 Sep 2024 13:16:29 +0200 Subject: [PATCH 1/3] fix rst --- flow/record/base.py | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/flow/record/base.py b/flow/record/base.py index aaa6595..b813db7 100644 --- a/flow/record/base.py +++ b/flow/record/base.py @@ -540,10 +540,12 @@ def fields(self) -> Mapping[str, RecordField]: """ Get fields mapping (without required fields). eg: - { - "foo": RecordField("foo", "string"), - "bar": RecordField("bar", "varint"), - } + .. code-block:: + + { + "foo": RecordField("foo", "string"), + "bar": RecordField("bar", "varint"), + } Returns: Mapping of Record fields From eaee99691a4080ce2bc62f14c270db2e3216080d Mon Sep 17 00:00:00 2001 From: JSCU-CNI <121175071+JSCU-CNI@users.noreply.github.com> Date: Wed, 25 Sep 2024 13:23:31 +0200 Subject: [PATCH 2/3] might as well fix it everywhere in base.py --- flow/record/base.py | 71 +++++++++++++++++++++++++-------------------- 1 file changed, 40 insertions(+), 31 deletions(-) diff --git a/flow/record/base.py b/flow/record/base.py index b813db7..08d8fa8 100644 --- a/flow/record/base.py +++ b/flow/record/base.py @@ -523,12 +523,14 @@ def get_required_fields() -> Mapping[str, RecordField]: """ Get required fields mapping. eg: - { - "_source": RecordField("_source", "string"), - "_classification": RecordField("_classification", "datetime"), - "_generated": RecordField("_generated", "datetime"), - "_version": RecordField("_version", "vaeint"), - } + .. code-block:: + + { + "_source": RecordField("_source", "string"), + "_classification": RecordField("_classification", "datetime"), + "_generated": RecordField("_generated", "datetime"), + "_version": RecordField("_version", "vaeint"), + } Returns: Mapping of required fields @@ -558,15 +560,17 @@ def get_all_fields(self) -> Mapping[str, RecordField]: """ Get all fields including required meta fields. eg: - { - "ts": RecordField("ts", "datetime"), - "foo": RecordField("foo", "string"), - "bar": RecordField("bar", "varint"), - "_source": RecordField("_source", "string"), - "_classification": RecordField("_classification", "datetime"), - "_generated": RecordField("_generated", "datetime"), - "_version": RecordField("_version", "varint"), - } + .. code-block:: + + { + "ts": RecordField("ts", "datetime"), + "foo": RecordField("foo", "string"), + "bar": RecordField("bar", "varint"), + "_source": RecordField("_source", "string"), + "_classification": RecordField("_classification", "datetime"), + "_generated": RecordField("_generated", "datetime"), + "_version": RecordField("_version", "varint"), + } Returns: Mapping of all Record fields @@ -593,18 +597,18 @@ def getfields(self, typename: str) -> RecordFieldSet: return RecordFieldSet(field for field in self.fields.values() if field.typename == name) def __call__(self, *args, **kwargs) -> Record: - """Create a new Record initialized with `args` and `kwargs`.""" + """Create a new Record initialized with ``args`` and ``kwargs``.""" return self.recordType(*args, **kwargs) def init_from_dict(self, rdict: dict[str, Any], raise_unknown=False) -> Record: - """Create a new Record initialized with key, value pairs from `rdict`. + """Create a new Record initialized with key, value pairs from ``rdict``. - If `raise_unknown=True` then fields on `rdict` that are unknown to this + If ``raise_unknown=True`` then fields on ``rdict`` that are unknown to this RecordDescriptor will raise a TypeError exception due to initializing with unknown keyword arguments. (default: False) Returns: - Record with data from `rdict` + Record with data from ``rdict`` """ if not raise_unknown: @@ -612,14 +616,14 @@ def init_from_dict(self, rdict: dict[str, Any], raise_unknown=False) -> Record: return self.recordType(**rdict) def init_from_record(self, record: Record, raise_unknown=False) -> Record: - """Create a new Record initialized with data from another `record`. + """Create a new Record initialized with data from another ``record``. - If `raise_unknown=True` then fields on `record` that are unknown to this + If ``raise_unknown=True`` then fields on ``record`` that are unknown to this RecordDescriptor will raise a TypeError exception due to initializing with unknown keyword arguments. (default: False) Returns: - Record with data from `record` + Record with data from ``record`` """ return self.init_from_dict(record._asdict(), raise_unknown=raise_unknown) @@ -635,7 +639,9 @@ def extend(self, fields: Sequence[tuple[str, str]]) -> RecordDescriptor: def get_field_tuples(self) -> tuple[tuple[str, str]]: """Returns a tuple containing the (typename, name) tuples, eg: - (('boolean', 'foo'), ('string', 'bar')) + .. code-block:: + + (('boolean', 'foo'), ('string', 'bar')) Returns: Tuple of (typename, name) tuples @@ -678,7 +684,7 @@ def __repr__(self) -> str: def definition(self, reserved: bool = True) -> str: """Return the RecordDescriptor as Python definition string. - If `reserved` is True it will also return the reserved fields. + If ``reserved`` is True it will also return the reserved fields. Returns: Descriptor definition string @@ -771,7 +777,7 @@ def open_path(path: str, mode: str, clobber: bool = True) -> IO: Args: path: Filename or path to filename to open mode: Could be "r", "rb" to open file for reading, "w", "wb" for writing - clobber: Overwrite file if it already exists if `clobber=True`, else raises IOError. + clobber: Overwrite file if it already exists if ``clobber=True``, else raises IOError. """ binary = "b" in mode @@ -1042,6 +1048,8 @@ def normalize_fieldname(field_name: str) -> str: This normalizes the name so it can still be used in flow.record. Reserved field_names are not normalized. + .. code-block:: + >>> normalize_fieldname("my-variable-name-with-dashes") 'my_variable_name_with_dashes' >>> normalize_fieldname("_my_name_starting_with_underscore") @@ -1102,25 +1110,26 @@ def __call__(self, *args, **kwargs): def iter_timestamped_records(record: Record) -> Iterator[Record]: - """Yields timestamped annotated records for each `datetime` fieldtype in `record`. - If `record` does not have any `datetime` fields the original record is returned. + """Yields timestamped annotated records for each ``datetime`` fieldtype in ``record``. + If ``record`` does not have any ``datetime`` fields the original record is returned. Args: record: Record to add timestamp fields for. Yields: - Record annotated with `ts` and `ts_description` fields for each `datetime` fieldtype. + Record annotated with ``ts`` and ``ts_description`` fields for each ``datetime`` fieldtype. """ - # get all `datetime` fields. (excluding _generated). + + # get all ``datetime`` fields. (excluding _generated). dt_fields = record._desc.getfields("datetime") if not dt_fields: yield record return - # yield a new record for each `datetime` field assigned as `ts`. + # yield a new record for each ``datetime`` field assigned as ``ts``. record_name = record._desc.name for field in dt_fields: ts_record = TimestampRecord(getattr(record, field.name), field.name) - # we extend `ts_record` with original `record` so TSRecord info goes first. + # we extend ``ts_record`` with original ``record`` so TSRecord info goes first. record = extend_record(ts_record, [record], name=record_name) yield record From 859aa215cc4ed1b93afb1361c89ecd7054ea8fbd Mon Sep 17 00:00:00 2001 From: JSCU-CNI <121175071+JSCU-CNI@users.noreply.github.com> Date: Wed, 25 Sep 2024 15:09:26 +0200 Subject: [PATCH 3/3] specify type --- flow/record/base.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/flow/record/base.py b/flow/record/base.py index 08d8fa8..43de77b 100644 --- a/flow/record/base.py +++ b/flow/record/base.py @@ -523,7 +523,7 @@ def get_required_fields() -> Mapping[str, RecordField]: """ Get required fields mapping. eg: - .. code-block:: + .. code-block:: text { "_source": RecordField("_source", "string"), @@ -542,7 +542,7 @@ def fields(self) -> Mapping[str, RecordField]: """ Get fields mapping (without required fields). eg: - .. code-block:: + .. code-block:: text { "foo": RecordField("foo", "string"), @@ -560,7 +560,7 @@ def get_all_fields(self) -> Mapping[str, RecordField]: """ Get all fields including required meta fields. eg: - .. code-block:: + .. code-block:: text { "ts": RecordField("ts", "datetime"), @@ -639,7 +639,7 @@ def extend(self, fields: Sequence[tuple[str, str]]) -> RecordDescriptor: def get_field_tuples(self) -> tuple[tuple[str, str]]: """Returns a tuple containing the (typename, name) tuples, eg: - .. code-block:: + .. code-block:: text (('boolean', 'foo'), ('string', 'bar')) @@ -1048,7 +1048,7 @@ def normalize_fieldname(field_name: str) -> str: This normalizes the name so it can still be used in flow.record. Reserved field_names are not normalized. - .. code-block:: + .. code-block:: text >>> normalize_fieldname("my-variable-name-with-dashes") 'my_variable_name_with_dashes'