2017-02-10 22:35:02 +01:00
|
|
|
"""Utility functions and classes for the stix2 library."""
|
|
|
|
|
|
|
|
import datetime as dt
|
2017-04-19 20:32:56 +02:00
|
|
|
import json
|
2017-02-10 22:35:02 +01:00
|
|
|
|
2017-04-25 00:29:56 +02:00
|
|
|
import pytz
|
|
|
|
|
2017-02-10 22:35:02 +01:00
|
|
|
# Sentinel value for fields that should be set to the current time.
|
|
|
|
# We can't use the standard 'default' approach, since if there are multiple
|
|
|
|
# timestamps in a single object, the timestamps will vary by a few microseconds.
|
|
|
|
NOW = object()
|
|
|
|
|
|
|
|
|
|
|
|
def get_timestamp():
|
|
|
|
return dt.datetime.now(tz=pytz.UTC)
|
|
|
|
|
|
|
|
|
|
|
|
def format_datetime(dttm):
|
2017-04-17 16:48:13 +02:00
|
|
|
# 1. Convert to timezone-aware
|
|
|
|
# 2. Convert to UTC
|
|
|
|
# 3. Format in ISO format
|
|
|
|
# 4. Add subsecond value if non-zero
|
|
|
|
# 5. Add "Z"
|
|
|
|
|
|
|
|
try:
|
|
|
|
zoned = dttm.astimezone(pytz.utc)
|
|
|
|
except ValueError:
|
2017-04-17 19:16:14 +02:00
|
|
|
# dttm is timezone-naive; assume UTC
|
|
|
|
pytz.utc.localize(dttm)
|
2017-04-17 16:48:13 +02:00
|
|
|
ts = zoned.strftime("%Y-%m-%dT%H:%M:%S")
|
|
|
|
if zoned.microsecond > 0:
|
|
|
|
ms = zoned.strftime("%f")
|
|
|
|
ts = ts + '.' + ms.rstrip("0")
|
|
|
|
return ts + "Z"
|
2017-04-19 20:32:56 +02:00
|
|
|
|
|
|
|
|
|
|
|
def get_dict(data):
|
|
|
|
"""Return data as a dictionary.
|
|
|
|
Input can be a dictionary, string, or file-like object.
|
|
|
|
"""
|
|
|
|
|
|
|
|
if type(data) is dict:
|
|
|
|
obj = data
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
obj = json.loads(data)
|
|
|
|
except TypeError:
|
|
|
|
obj = json.load(data)
|
|
|
|
|
|
|
|
return obj
|