Skip to content

Latest commit

 

History

History
1301 lines (788 loc) · 31.3 KB

CHANGELOG.md

File metadata and controls

1301 lines (788 loc) · 31.3 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Changes are grouped as follows

  • Added for new features.
  • Changed for changes in existing functionality.
  • Deprecated for soon-to-be removed features.
  • Removed for now removed features.
  • Fixed for any bug fixes.
  • Security in case of vulnerabilities.

7.6.7

Changed

  • Loosened dependency restrictions on 0.* packages

7.5.6

Added

  • Added a ssl_verify argument to file uploaders to either use custom CA bundles or to diable SSL verification completely.

7.5.5

Added

  • Added a feature to report file upload errors

Changed

  • Improved logging when uploading files

Fixed

  • Handling of files with size 0

7.5.4

Fixed

  • Fix issue caused by attempting to update file mimeType on AWS clusters.

7.5.3

Fixed

  • Revert change in 7.5.2, the root cause is a different issue.

7.5.2

Fixed

  • Avoid trying to update mime type when updating empty files.

7.5.1

Changed

  • The file upload queue will now use file_transfer_timeout from the passed CogniteClient.

7.5.0

Added

  • File processing utils

7.4.9

Added

  • CastableInt class the represents an interger to be used in config schema definitions. The difference from using int is that the field of this type in the yaml file can be either a string or a number, while a field of type int must be a number in yaml.
  • PortNumber class that represents a valid port number to be used in config schema definitions. Just like CastableInt it can be a string or a number in the yaml file. This allows for example setting a port number using an environment variable.

7.4.8

Fixed

  • Fix file upload when private link is used

7.4.7

Added

  • Configuration for ignore regexp pattern

7.4.6

Fixed

  • Fix file metadata update

7.4.5

Removed

  • Remove warnings from data models file uploads

7.4.4

Changed

  • Updated cognite SDK version.

7.4.3

Fixed:

  • Regression: Reverting change related to file_meta parameter in IOUploadQueue

7.4.2

Added

  • Added support for AWS file upload

7.4.1

Changed

  • Updated cognite sdk version

7.4.0

Added

  • Upload to Core DM/Classic file.

7.3.0

Changed

  • Use httpx to upload files to CDF instead of the python SDK. May improve performance on windows.

7.2.3

Added

  • Add additional validation to cognite config before creating a cognite client, to provide better error messages when configuration is obviously wrong.

7.2.2

Fixed

  • Produce a config error when missing token-url and tenant, instead of eventually producing an OAuth 2 MUST utilize https error when getting the token.

7.2.1

Changed

  • Reformat log messages to not have newlines

Fixed

  • Fixed using the keyvault tag in remote config.

7.2.0

Fixed

  • Fixed an issue with the retry decorator where functions would not be called at all if the cancellation token was set. This resulted in errors with for example upload queues.

Added

  • An upload queue for data model instances.
  • A new type of state store that stores hashes of ingested items. This can be used to detect changed RAW rows or data model instances.

7.1.6

Changed

  • Update cognite-sdk version to 7.43.3

7.1.5

Fixed

  • Fixed an issue preventing retries in file uploads from working properly

Added

  • File external ID when logging failed file uploads

7.1.4

Fixed

  • Fixed a race condition in state stores and uploaders where a shutdown could result in corrupted state stores.

7.1.3

Fixed

  • Update type hints for the time series upload queue to allow status codes

7.1.2

Fixed

  • cognite_exceptions() did not properly retry file uploads

7.1.1

Fixed

  • Enhancement of 7.0.5: more use cases covered (to avoid repeatedly fetching a new token).
  • When using remote config, the full local idp-authentication is now injected (some fields were missing).

7.1.0

Added

  • The file upload queue is now able to stream files larger than 5GiB.

7.0.5

Fixed

  • The background thread ConfigReloader now caches the CogniteClient to avoid repeatedly fetching a new token.

7.0.4

Fixed

  • Max parallelism in file upload queue properly can set larger values than the max_workers in the ClientConfig object.
  • Storing states with the state store will lock the state store. This fixes an issue where iterating through a changing dict could cause issues.

7.0.3

Fixed

  • Fix file size upper limit.

7.0.2

Added

  • Support for files without content.

7.0.1

Fixed

  • Ensure that CancellationToken.wait(timeout) only waits for at most timeout, even if it is notified in that time.

7.0.0

Changed

  • The file upload queues have changed behaviour.

    • Instead of waiting to upload until a set of conditions, it starts uploading immedeately.
    • The upload() method now acts more like a join, wating on all the uploads in the queue to complete before returning.
    • A call to add_to_upload_queue when the queue is full will hang until the queue is no longer full before returning, instead of triggering and upload and hanging until everything is uploaded.
    • The queues now require to be set up with a max size. The max upload latencey is removed. As long as you use the queue in as a context (ie, using with FileUploadQueue(...) as queue:) you should not have to change anything in your code. The behaviour of the queue will change, it will most likely be much faster, but it will not require any changes from you as a user of the queue.
  • threading.Event has been replaced globally with CancellationToken. The interfaces are mostly compatible, though CancellationToken does not have a clear method. The compatibility layer is deprecated.

    • Replace calls to is_set with the property is_cancelled.
    • Replace calls to set with the method cancel.
    • All methods which took threading.Event now take CancellationToken. You can use create_child_token to create a token that can be canceled without affecting its parent token, this is useful for creating stoppable sub-modules that are stopped if a parent module is stopped. Notably, calling stop on an upload queue no longer stops the parent extractor, this was never intended behavior.

Removed

  • The deprecated middleware module has been removed.
  • set_event_on_interrupt has been replaced with CancellationToken.cancel_on_interrupt.

Added

  • You can now use Path as a type in your config files.
  • CancellationToken as a better abstraction for cancellation than threading.Event.

Migration guide

To migrate from version 6.* to 7, you need to update how you interract with cancellation tokens. The type has now changed from Event to CancellationToken, so make sure to update all of your type hints etc. There is a compatability layer for the CancellationToken class, so that it has the same methods as an Event (except for clear()) which means it should act as a drop-in replacement for now. This compatability layer is deprected, and will be removed in version 8.

If you are using file upload queues, read the entry in the Changed section. You will most likely not need to change your code, but how the queue behaves has changed for this version.

[6.4.1]

Changed

  • File upload queues now reuse a single thread pool across runs instead of creating a new one each time upload() is called.

[6.4.0]

Added

  • Option to specify retry exceptions as a dictionary instead of a tuple. Values should be a callable determining whether a specific exception object should be retied or not. Example:

    @retry(
        exceptions = {ValueError: lambda x: "Invalid" not in str(x)}
    )
    def func() -> None:
        value = some_function()
    
        if value is None:
            raise ValueError("Could not retrieve value")
    
        if not_valid(value):
            raise ValueError(f"Invalid value: {value}")
  • Templates for common retry scenarios. For example, if you're using the requests library, you can do

    retry(exceptions = request_exceptions())

Changed

  • Default parameters in retry has changed to be less agressive. Retries will apply backoff by default, and give up after 10 retries.

[6.3.2]

Added

  • Aliases for keyvault config to align with dotnet utils

[6.3.1]

Fixed

  • Improved the state store retry behavior to handle both fundamental and wrapped network connection errors.

[6.3.0]

Added

  • Added support to retrieve secrets from Azure Keyvault.

[6.2.2]

Added

  • Added an optional security-categories attribute to the cognite config section.

[6.2.1]

Fixed

  • Fixed a type hint in the post_upload_function for upload queues.

[6.2.0]

Added

  • Added IOFileUploadQueue as a base class of both FileUploadQueue and BytesUploadQueue. This is an upload queue for functions that produce BinaryIO to CDF Files.

[6.1.1]

Fixed

  • Correctly handle equality comparison of TimeIntervalConfig objects.

[6.1.0]

Added

  • Added ability to specify dataset under which metrics timeseries are created

[6.0.2]

Fixed

  • Improved the state store retry behavior to handle connection errors

[6.0.1]

Fixed

  • Fixed iter method on the state store to return an iterator

[6.0.0]

Changed

  • cognite-sdk to v7

[5.5.1]

Added

  • Added iter method on the state store to return the keys of the local state dict

[5.5.0]

Added

  • Added load_yaml_dict to configtools.loaders.

Fixed

  • Fixed getting the config type when !env was used in the config file.

[5.4.3]

Added

  • Added len method on the state store to return the length of the local state dict

[5.4.2]

Fixed

  • Fix on find_dotenv call

[5.4.1]

Changed

  • Update cognite-sdk version to 6.24.0

[5.4.0]

Fixed

  • Fixed the type hint for the retry decorator. The list of exception types must be given as a tuple, not an arbitrary iterable.
  • Fixed retries for sequence upload queue.
  • Sequence upload queue reported number of distinct sequences it had rows for, not the number of rows. That is now changed to number of rows.
  • When the sequence upload queue uploaded, it always reported 0 rows uploaded because of a bug in the logging.

Removed

  • Latency metrics for upload queues.

[5.3.0]

Added

  • Added support for queuing assets upload

[5.2.1]

Changed

  • Timestamps before 1970 are no longer filtered out, to align with changes to the timeseries API.

[5.2.0]

Changed

  • The event upload queue now upserts events. If creating an event fails due to the event already existing, it will be updated instead.

[5.1.0]

Added

  • Support for connection parameters

[5.0.1]

Changed

  • Upload queue size limit now triggers an upload when the size has reached the limit, not when it exceeded the limit.

[5.0.0]

Removed

  • Legacy authentication through API keys has been removed throughtout the code base.

  • A few deprecated modules (authentication, prometheus_logging) have been deleted.

Changed

  • uploader and configtools have been changed from one module to a package of multiple modules. The content has been re-exported to preserve compatability, so you can still do

    from cognite.extractorutils.configtools import load_yaml, TimeIntervalConfig
    from cognite.extractorutils.uploader import TimeSeriesUploadQueue

    But now, you can also import from the submodules directly:

    from cognite.extractorutils.configtools.elements import TimeIntervalConfig
    from cognite.extractorutils.configtools.loaders import load_yaml
    from cognite.extractorutils.uploader.time_series import TimeSeriesUploadQueue

    This has first and foremost been done to improve the codebase and make it easier to continue to develop.

  • Updated the version of the Cognite SDK to version 6. Refer to the changelog and migration guide for the SDK for details on the changes it entails for users.

  • Several small single-function modules have been removed and the content have been moved to the catch-all util module. This includes:

    • The add_extraction_pipeline decorator from the extraction_pipelines module

    • The throttled_loop generator from the throttle module

    • The retry decorator from the retry module

Added

  • Support for audience parameter in idp-authentication

Migration guide

The deletion of API keys and the legacy OAuth2 implementation should not affect your extractors or your usage of the utils unless you were depending on the old OAuth implementation directly and not through configtools or the base classes.

To update to version 5 of extractor-utils, you need to

  • Change where you import a few things.

    • Change from

      from cognite.extractorutils.extraction_pipelines import add_extraction_pipeline

      to

      from cognite.extractorutils.util import add_extraction_pipeline
    • Change from

      from cognite.extractorutils.throttle import throttled_loop

      to

      from cognite.extractorutils.util import throttled_loop
    • Change from

      from cognite.extractorutils.retry import retry

      to

      from cognite.extractorutils.util import retry
  • Consult the migration guide for the Cognite SDK version 6 for details on the changes it entails for users.

The changes in this version are only breaking for your usage of the utils. Any extractor you have written will not be affected by the changes, meaning you do not need to bump the major version for your extractors.

[4.3.1]

Changed

  • Default size of RAW queues is now 50 000 for UploaderExtractors as well.

[4.3.0]

Added

  • FileSizeConfig class, similar to TimeIntervalConfig, that allows human readable formats such as 1 kb or 3.7 mib, as well as bytes directly. It then computes properties for bytes, kilobytes, etc.

[4.2.1]

Fixed

  • Fixed a bug in the state store when decimal valued incremental fields are used.

[4.2.0]

Added

  • Add support for certificate authentication

Changed

  • Change minimum cognite-sdk version to 5.8

[4.1.0]

Changed

  • Update cognite-sdk version to 5.1.1

[4.0.1]

Fixed

  • Fixed a bug in the error handling for reporting heartbeats.

[4.0.0]

Added

  • Allow indexing state stores. You can now use the indexing notation to access values in a state store like you would do e.g. in a dictionary. Examples:

    states = LocalStateStore(...)
    
    # You can now set states like so:
    states["id"] = (None, 5)
    
    # Getting current states:
    low, high = states["another_id"]
    
    # You can also check if an entry has a stored state with the 'in' operator:
    if "new_id" not in states:
        # do something you only do the first time you process an item

Fixed

  • Fixed a typo throughout the library, cancelation_token is now called cancellation_token everywhere. If you ever e.g. specify a cancellation token in a keyword argument, make sure to update the spelling.

Changed

  • Allow any interval to be configured as a string in addition to integers, so e.g. upload intervals can be configured as

    upload-interval: 2m

    with s/m/h/d being valid units, and s being implied when units are missing (to preserve backwards compatibility with old config files). If your extractor reads from these config fields you need to update to read the seconds (or the computed minutes, hours or days ) attribute instead of the fields directly, for example:

    RawUploadQueue(
        cognite_client,
        max_upload_interval=config.upload_interval,
    )

    must be changed to

    RawUploadQueue(
        cognite_client,
        max_upload_interval=config.upload_interval.seconds,
    )

Migration guide

In order to update from version 3 to version 4, you need to:

  • Change cancelation_token to cancellation_token every time you pass one as a keyword argument (or read from an attribute)
  • Access the seconds attribute from any time values you read from the default config (such as upload_intervals or timeouts)
  • Consider updating any time value you have in your own config parameters to be of TimeIntervalConfig instead of int to allow users the option of configuring time values in a human-readable format.

A type checker, like mypy, will be able to detect any breaking changes this update introduces. We highly reccomend scanning your code with a type checker.

Updating from version 3 to 4 should not introduce breaking changes to your extractor.

[3.2.0]

Added

  • Decorator which adds extraction pipeline functionality

[3.1.4]

Fixed

  • Correctly catch errors when reloading remote configuration files

[3.1.1]

Fixed

  • Support running extractor utils inside Cognite Functions

[3.1.0]

Added

  • Support for exposing prometheus metrics on a local port instead of pushing to pushgateway

[3.0.2]

Fixed

  • Remove old version warning from the cognite SDK.

[3.0.1]

Fixed

  • Correctly do not request the experimental SDK when using remote configuration files

[3.0.0]

Added

  • SequenceUploadQueue's create_missing funtionality can now be used to set Name and Description values on newly created sequences.
  • Remote configuration files is now fully released and supported without using the experimental SDK.

Fixed

  • Dataset and linked asset information are correctly set on created sequences.
  • Type hint for sequence column definitions updated to be more consistent.

[3.0.0-beta4]

Added

  • Option to set data set id when creating missing time series in the time series upload queue.

[3.0.0-beta2]

Changed

  • Update cognite-sdk to version 4.0.1, which removes the support for reserved environment variables such as COGNITE_API_KEY and COGNITE_CLIENT_ID.

[3.0.0-beta]

Removed

  • Python 3.7 support

Preview release of remote configuration of extractors. This allows users of your extractors to configure their extractors from CDF.

Migration guide

In this section we will go through how you can start using remote configuration in your extractors.

Loading configs on startup

If you have based your extractor on the Extractor base class, remote configuration is already implemented for your extractor without any need for further changes to your code.

To include the feature, you must update cognite-extractor-utils to 2.3.0-beta1, and add a dependency to cognite-sdk-experimental version >=0.76.0.

Otherwise, you must use the new ConfigResolver class in the configtools module:

# With automatic CLI (ie, read config from command line args):
resolver = ConfigResolver.from_cli(
    name="my extractor",
    description="Short description of my extractor",
    version="1.2.3",
    config_type=MyConfig,
)
config: MyConfig = resolver.config


# With path to a yaml file:
resolver = ConfigResolver(
    config_path="/path/to/config.yaml",
    config_type=MyConfig
)
config: MyConfig = resolver.config

The resolver will automatically fetch configuration from CDF if remote configuration is used, otherwise it will return the same as load_yaml.

Detecting config changes (only when using the base class)

When using the base class, you have the option to automatically detect new config revisions, and do one of several predefined actions (keep in mind that this is not exclusive to remote configs, if the extractor is running with a local configuration that changes, it will do the same action). You specify which with an reload_config_action enum. The enum can be one of the following values:

  • DO_NOTHING which is the default
  • REPLACE_ATTRIBUTE which will replace the config attribute on the object (keep in mind that if you are using the run_handle instead of subclassing, this will have no effect). Be also aware that anything that is set up based on the config (upload queues, cognite client objects, loggers, connections to source, etc) will not change in this case.
  • SHUTDOWN will set the cancelation_token event, and wait for the extractor to shut down. It is then intended that the service layer running the extractor (ie, windows services, systemd, docker, etc) will be configured to always restart the service if it shuts down. This is the recomended approach for reloading configs, as it is always guaranteed that everything will be re-initialized according to the new configuration.
  • CALLBACK is similar to REPLACE_ATTRIBUTE with one difference. After replacing the config attribute on the extractor object, it will call the reload_config_callback method, which you will have to override in your subclass. This method should then do any necessary cleanup or re-initialization needed for your particular extractor.

To enable detection of config changes, set the reload_config_action argument to the Extractor constructor to your chosen action:

# Using run handle:
with Extractor(
    name="my_extractor",
    description="Short description of my extractor",
    config_class=MyConfig,
    version="1.2.3",
    run_handle=run_extractor,
    reload_config_action=ReloadConfigAction.SHUTDOWN,
) as extractor:
    extractor.run()

# Using subclass:
class MyExtractor(Extractor):
    def __init__(self):
        super().__init__(
            name="my_extractor",
            description="Short description of my extractor",
            config_class=MyConfig,
            version="1.2.3",
            reload_config_action=ReloadConfigAction.SHUTDOWN,
        )

The extractor will then periodically check if the config file has changed. The default interval is 5 minutes, you can change this by setting the reload_config_interval attribute. As with any other interval in extractor-utils, the unit is seconds.

Using remote configuration

When using remote configuration, you will still need to configure the extractor with some minimal parameters - namely a CDF project, credentials for that project, and an extraction pipeline ID to fetch configs from. There is also a new global config field named type which is either remote or local (which is the default).

An example for this minimal config follows:

type: remote

cognite:
    # Read these from environment variables
    host: ${COGNITE_BASE_URL}
    project: ${COGNITE_PROJECT}

    idp-authentication:
        token-url: ${COGNITE_TOKEN_URL}
        client-id: ${COGNITE_CLIENT_ID}
        secret: ${COGNITE_CLIENT_SECRET}
        scopes:
            - ${COGNITE_BASE_URL}/.default

    extraction-pipeline:
        external-id: my-extraction-pipeline

The config file stored in CDF should omit all of these fields, as they will be overwritten by the ConfigResolver to be the values given here. In other words, for most extractor deployments, you should be able to leave out the cognite field in the config stored in CDF.

[2.2.0] - 2022-04-01

Added

  • .env files will now be loaded if present at runtime
  • Check that a configured extraction pipeline actually exists, and report an appropriate error if not.

Fixed

  • A few type hints in retry module were more restrictive than needed (such as requiring int when float would work).
  • Gracefully handle wrongful data in state stores. If JSON parsing fails, use an empty state store as default.

Changed

  • Exception messages for InvalidConfigErrors have been improved, and when using the extractor base class it will print them in a formatted way instead of dumping a stack trace on invalid configs.

[2.1.3] - 2022-03-07

Fixed

  • Use Optional with defaults in code instead of dataclass defaults in UploaderExtractorConfig, as this allows non-default config sections in subclasses.

[2.1.2] - 2022-03-07

Fixed

  • Include defaults for queue sizes in UploaderExtractor

[2.1.1] - 2022-03-04

Changed

  • Allow wider ranges for certain dependencies
    • Allow >=3.7.4, <5 for typing-extensions
    • Allow >=5.3.0, <7 for PyYAML

[2.1.0] - 2022-02-25

Added

  • uploader_extractor and uploader_types modules used to create extractors writing to events, timeseries, or raw, by calling a common method. This is primarily used for the utils extensions, but can be useful for very simple extractors in general.

Fixed

  • Fixed a signature bug in SequenceUploadQueue's __enter__ method preventing it to be used as a context.

[2.0.3] - 2022-02-08

Fixed

  • Fixed an issue where the base class would not always load a default LocalStateStore if requested

[2.0.2] - 2022-02-07

Added

  • A get_current_state_store class method on the Extractor class which returns the most recent state store loaded

[2.0.1] - 2022-02-01

Fixed

  • Fixed retries to not block the GIL and respect the cancellation token

Added

  • A get_current_config class method on the Extractor class which returns the most recent config file read

[2.0.0] - 2022-01-24

Added

  • Option to not handle SIGINTs gracefully
  • Configurable heartbeat interval

Changed

  • Use cognite-sdk-core as base instead of cognite-sdk
  • Update Arrow to >1.0.0

Migration guide

To update your projects to 2.0.0 there are two things to consider:

  • If you are specifying a version of the Cognite SDK to use in your dependency list, you must now specify cognite-sdk-core instead. Otherwise you might install both versions. E.g. If your pyproject.toml looks like this:

    cognite-sdk = "^2.32.0"
    cognite-extractor-utils = "^1.3.3"

    You must also change the cognite-sdk dependency when updating extractor-utils:

    cognite-sdk-core = "^2.32.0"
    cognite-extractor-utils = "^2.0.0"
  • If your extractor is using the included Arrow package, there are a few breaking changes (most notibly that the timestamp attribute is renamed to int_timestamp). Consult their migration guide to make sure you are in compliance.

[1.6.2] - 2022-01-22

Changed

  • Allow environment variable substitution in bool type config fields without breaking generic environment variable substitution

[1.6.1] - 2022-01-21

Changed

  • Reverts 1.6.0 as it broke generic environment variable substitution

[1.6.0] - 2022-01-21

Fixed

  • Allow environment variable substitution in bool type config fields

[1.5.4] - 2021-11-17

Fixed

  • Make Cognite SDK timeout configurable

[1.5.3] - 2021-10-12

Fixed

  • Add a base class for extractors to remove a lot of boilerplate code necesarry for startup/shutdown, initialization etc.

[1.5.2] - 2021-09-27

Fixed

  • Allow using Enums in config classes

[1.5.1] - 2021-09-24

Added

  • An ensure_assets function similar to ensure_timeseries
  • A BytesUploadQueue that takes byte arrays directly instead of file paths
  • A throttled_loop generator that iterates at most every n seconds
  • An EitherIdConfig to configure e.g. data sets with either an id or external id in the same field.

Changed

  • Never call /login/status as the endpoint is deprecated

Fixed

  • Inlcude missing classes and modules in docs

Deprecated

  • Using dataset-id or dataset-external-id fields, use the new EitherIdConfig instead.

[1.5.0] - 2021-08-12

Added

  • Add a base class for extractors to remove a lot of boilerplate code necesarry for startup/shutdown, initialization etc.

[1.4.2] - 2021-06-01

Fixed

  • Fix an issue in SequenceUploadQueue.add_to_upload_queue when adding multiple rows to the same id

[1.4.1] - 2021-05-03

Changed

  • Changed bucket sizes for observed times in uploader metrics to be more suited for expected values.

[1.4.0] - 2021-04-13

Added

  • Option to provide additional custum args to token fetching (via the token_custom_args arg to the CogniteClient constructor)

Changed

  • Use token fetching from Cognite SDK instead of our own implementation

Deprecated

  • Authenticator class

[1.3.4] - 2021-03-31

Added

  • Add config parameter to enable metrics of log messages. It reveals how many logging events happened per logger and log-level.

[1.3.3] - 2021-03-30

Changed

  • Reduce cardinality (by reducing label count) on autogenerated metrics. E.g. don't label TIMESERIES_UPLOADER_POINTS_WRITTEN with which time series it's writing to.

[1.3.2] - 2021-03-29

Added

  • Add option to specify external IDs for data sets

[1.3.1] - 2021-03-22

Fixed

  • Fix labels for generated Prometheus

[1.3.0] - 2021-03-15

Fixed

  • Add a cancellation token to all data uploaders and metrics pushers
  • Add various automatic Prometheus metrics for data uploaders

[1.2.4] - 2021-03-02

Fixed

  • Fix URL creation in OAuth flow

[1.2.3] - 2021-01-07

Fixed

  • Fix a pool issue in FileUploadQueue

[1.2.2] - 2020-12-07

Added

  • General OIDC token support

[1.2.1] - 2020-10-20

Added

  • Add option to authenticate to CDF with AAD

[1.2.0] - 2020-09-16

Added

  • Add upload queues for sequences and files

Fixed

  • TimeSeriesUploadQueue can now auto-create string time series

[1.1.1] - 2020-08-27

Added

  • Add option to create missing time series from upload queue

Fix

  • Fixed an issue in EitherId where the repr method didn't return a string (as would be expected).

[1.1.0] - 2020-08-25

Added

  • Add py.typed file so mypy knows that package is typed

[1.0.2] - 2020-06-02

Fixed

  • Don't require auth for prometheus push gateways as push gateways can be configured to allow unauthorized access.
  • Fixed a bug where the state store config would not allow raw state stores without explicit null on local

[1.0.1] - 2020-05-25

Added

  • An outside_state method to test if a new proposed state in state stores is covered or not
  • A general SIGINT handler
  • Several minor additions to configtools: Defaults in StateStoreConfig, optional dataset ID in CogniteConfig, option to have version as int or None
  • Add a metrics factory that caches instances

Fixed

  • A concurrency issue with TimeSeriesUploadQueue where uploads could fail if points were added at the very start of the upload call
  • Fix documentation build

[1.0.0] - 2020-05-15

Release the first stable version. Open source the library under the Apache 2.0 license