![JAR search and dependency download from the Maven repository](/logo.png)
com.ning.billing.meter.timeline.persistent.TimelineDao Maven / Gradle / Ivy
/*
* Copyright 2010-2012 Ning, Inc.
*
* Ning 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 com.ning.billing.meter.timeline.persistent;
import java.util.List;
import javax.annotation.Nullable;
import org.joda.time.DateTime;
import org.skife.jdbi.v2.exceptions.CallbackFailedException;
import org.skife.jdbi.v2.exceptions.UnableToObtainConnectionException;
import com.ning.billing.meter.timeline.categories.CategoryRecordIdAndMetric;
import com.ning.billing.meter.timeline.chunks.TimelineChunk;
import com.ning.billing.meter.timeline.consumer.TimelineChunkConsumer;
import com.ning.billing.meter.timeline.shutdown.StartTimes;
import com.ning.billing.util.callcontext.CallContext;
import com.ning.billing.util.callcontext.TenantContext;
import com.google.common.collect.BiMap;
public interface TimelineDao {
// Sources table
Integer getSourceId(String source, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
String getSource(Integer sourceId, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
BiMap getSources(TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
int getOrAddSource(String source, CallContext context) throws UnableToObtainConnectionException, CallbackFailedException;
// Event categories table
Integer getEventCategoryId(String eventCategory, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
String getEventCategory(Integer eventCategoryId, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
BiMap getEventCategories(TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
int getOrAddEventCategory(String eventCategory, CallContext context) throws UnableToObtainConnectionException, CallbackFailedException;
// Metrics table
Integer getMetricId(int eventCategory, String metric, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
CategoryRecordIdAndMetric getCategoryIdAndMetric(Integer metricId, TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
BiMap getMetrics(TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
int getOrAddMetric(Integer eventCategoryId, String metric, CallContext context) throws UnableToObtainConnectionException, CallbackFailedException;
// Timelines tables
Long insertTimelineChunk(TimelineChunk timelineChunk, CallContext context) throws UnableToObtainConnectionException, CallbackFailedException;
void getSamplesBySourceIdsAndMetricIds(List sourceIds,
@Nullable List metricIds,
DateTime startTime,
DateTime endTime,
TimelineChunkConsumer chunkConsumer,
TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
Integer insertLastStartTimes(StartTimes startTimes, CallContext context);
StartTimes getLastStartTimes(TenantContext context);
void deleteLastStartTimes(CallContext context);
void bulkInsertTimelineChunks(List timelineChunkList, CallContext context);
void test(TenantContext context) throws UnableToObtainConnectionException, CallbackFailedException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy