/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.nifi.provenance.store; import java.io.Closeable; import java.io.IOException; import java.util.List; import java.util.Optional; import java.util.concurrent.TimeUnit; import org.apache.nifi.provenance.ProvenanceEventRecord; import org.apache.nifi.provenance.authorization.EventAuthorizer; import org.apache.nifi.provenance.store.iterator.EventIterator; public interface EventStorePartition extends Closeable { /** * Performs any initialization routines that need to happen before the store is used * * @throws IOException if unable to perform initialization */ void initialize() throws IOException; /** * Adds the given events to the store * * @param events the events to add * @return a mapping of event to the location where it was stored * @throws IOException if unable to add the events */ StorageResult addEvents(Iterable<ProvenanceEventRecord> events) throws IOException; /** * @return the number of bytes occupied by the events in the store */ long getSize(); /** * @return the largest Event ID that has been written to this store, or -1 if no events have yet been stored. */ long getMaxEventId(); /** * Retrieves the event with the given ID * * @param id the ID of the event to retrieve * @return the Event with the given ID, or <code>null</code> if the event cannot be found * @throws IOException if unable to read the event from storage */ Optional<ProvenanceEventRecord> getEvent(long id) throws IOException; /** * Retrieves up to maxRecords events from the store, starting with the event whose ID is equal to firstRecordId. If that * event cannot be found, then the first event will be the oldest event in the store whose ID is greater than firstRecordId. * All events will be returned in the order that they were written to the store. I.e., all events will have monotonically * increasing Event ID's. * * @param firstRecordId the ID of the first event to retrieve * @param maxEvents the maximum number of events to retrieve. The actual number of results returned may be less than this. * @param authorizer the authorizer that should be used to filter out any events that the user doesn't have access to * @return a List of ProvenanceEventRecord's * @throws IOException if unable to retrieve records from the store */ List<ProvenanceEventRecord> getEvents(long firstRecordId, int maxEvents, EventAuthorizer authorizer) throws IOException; /** * Returns an {@link EventIterator} that is capable of iterating over the events in the store beginning with the given * record id. The events returned by the EventIterator will be provided in the order in which they were stored in the * partition. All events retrieved from this EventIterator will have monotonically increasing Event ID's. * * @param minimumEventId the minimum value of any Event ID that should be returned * @return an EventIterator that is capable of iterating over events in the store */ EventIterator createEventIterator(long minimumEventId); /** * Returns an {@link EventIterator} that iterates over the given event ID's and returns one ProvenanceEventRecord for * each given, if the ID given can be found. If a given ID cannot be found, it will be skipped and no error will be reported. * * @param eventIds the ID's of the events to retrieve * @return an EventIterator that iterates over the given event ID's */ EventIterator createEventIterator(List<Long> eventIds); /** * Purges any events from the partition that are older than the given amount of time * * @param olderThan the amount of time for which any event older than this should be removed * @param timeUnit the unit of time that applies to the first argument */ void purgeOldEvents(long olderThan, TimeUnit timeUnit); /** * Purges some number of events from the partition. The oldest events will be purged. * * @return the number of bytes purged from the partition */ long purgeOldestEvents(); }