Filter Events

"""Filter events of a archivist connection given url to Archivist and user Token.

Main function parses in a url to the Archivist and credentials, which is a user authorization.
The main function would initialize an archivist connection using the url and
the credentials, called "arch", then call with appropriate properties and

from os import getenv
from warnings import filterwarnings

from archivist.archivist import Archivist

filterwarnings("ignore", message="Unverified HTTPS request")

def main():
    """Main function of filtering events.

    Parse in user input of url and credentials token and use them to
    create an example archivist connection and passed-in properties
    attributes to filter all events of the selected properties.

    # client id and client secret is obtained from the appidp endpoint - see the
    # application registrations example code in examples/
    # client id is an environment variable. client_secret is stored in a file in a
    # directory that has 0700 permissions. The location of this file is set in
    # the client_secret_file environment variable.
    client_id = getenv("DATATRAILS_APPREG_CLIENT")
    client_secret_file = getenv("DATATRAILS_APPREG_SECRET_FILENAME")
    with open(client_secret_file, mode="r", encoding="utf-8") as tokenfile:
        client_secret =

    # Initialize connection to Archivist
    with Archivist(
        (client_id, client_secret),
    ) as arch:
        # Get all events with required attributes and properties
        props = {"confirmation_status": "CONFIRMED"}
        attrs = {"arc_display_type": "Traffic light"}
        for event in"assets/-", props=props, attrs=attrs):
            print("event", event)

        # alternatively one could pull the list and cache locally...
        events ="assets/-", props=props, attrs=attrs)
        for event in events:
            print("event", event)

if __name__ == "__main__":