blob: fb681be8bc8646ae65f72bd51cf43fa956422703 [file] [log] [blame]
/*
* 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.skywalking.oap.server.core.analysis.manual.spanattach;
import lombok.Getter;
import lombok.Setter;
import org.apache.skywalking.oap.server.core.analysis.Stream;
import org.apache.skywalking.oap.server.core.analysis.record.Record;
import org.apache.skywalking.oap.server.core.analysis.worker.RecordStreamProcessor;
import org.apache.skywalking.oap.server.core.source.ScopeDeclaration;
import org.apache.skywalking.oap.server.core.storage.StorageID;
import org.apache.skywalking.oap.server.core.storage.annotation.BanyanDB;
import org.apache.skywalking.oap.server.core.storage.annotation.Column;
import org.apache.skywalking.oap.server.core.storage.type.Convert2Entity;
import org.apache.skywalking.oap.server.core.storage.type.Convert2Storage;
import org.apache.skywalking.oap.server.core.storage.type.StorageBuilder;
import static org.apache.skywalking.oap.server.core.source.DefaultScopeDefine.SPAN_ATTACHED_EVENT;
@Setter
@Getter
@ScopeDeclaration(id = SPAN_ATTACHED_EVENT, name = "SpanAttachedEvent")
@Stream(name = SpanAttachedEventRecord.INDEX_NAME, scopeId = SPAN_ATTACHED_EVENT, builder = SpanAttachedEventRecord.Builder.class, processor = RecordStreamProcessor.class)
@BanyanDB.TimestampColumn(SpanAttachedEventRecord.TIMESTAMP)
public class SpanAttachedEventRecord extends Record {
public static final String INDEX_NAME = "span_attached_event_record";
public static final String START_TIME_SECOND = "start_time_second";
public static final String START_TIME_NANOS = "start_time_nanos";
public static final String EVENT = "event";
public static final String END_TIME_SECOND = "end_time_second";
public static final String END_TIME_NANOS = "end_time_nanos";
public static final String TRACE_REF_TYPE = "trace_ref_type";
public static final String RELATED_TRACE_ID = "related_trace_id";
public static final String TRACE_SEGMENT_ID = "trace_segment_id";
public static final String TRACE_SPAN_ID = "trace_span_id";
public static final String DATA_BINARY = "data_binary";
public static final String TIMESTAMP = "timestamp";
@Column(name = START_TIME_SECOND)
private long startTimeSecond;
@Column(name = START_TIME_NANOS)
private int startTimeNanos;
@Column(name = EVENT)
@BanyanDB.SeriesID(index = 0)
private String event;
@Column(name = END_TIME_SECOND)
private long endTimeSecond;
@Column(name = END_TIME_NANOS)
private int endTimeNanos;
@Column(name = TRACE_REF_TYPE)
private int traceRefType;
@Column(name = RELATED_TRACE_ID)
private String relatedTraceId;
@Column(name = TRACE_SEGMENT_ID)
private String traceSegmentId;
@Column(name = TRACE_SPAN_ID)
private String traceSpanId;
@Column(name = DATA_BINARY, storageOnly = true)
private byte[] dataBinary;
@Setter
@Getter
@Column(name = TIMESTAMP)
private long timestamp;
@Override
public StorageID id() {
return new StorageID()
.append(TRACE_SEGMENT_ID, traceSegmentId)
.append(START_TIME_SECOND, startTimeSecond)
.append(START_TIME_NANOS, startTimeNanos)
.append(EVENT, event);
}
public static class Builder implements StorageBuilder<SpanAttachedEventRecord> {
@Override
public SpanAttachedEventRecord storage2Entity(Convert2Entity converter) {
final SpanAttachedEventRecord record = new SpanAttachedEventRecord();
record.setStartTimeSecond(((Number) converter.get(START_TIME_SECOND)).longValue());
record.setStartTimeNanos(((Number) converter.get(START_TIME_NANOS)).intValue());
record.setEvent((String) converter.get(EVENT));
record.setEndTimeSecond(((Number) converter.get(END_TIME_SECOND)).longValue());
record.setEndTimeNanos(((Number) converter.get(END_TIME_NANOS)).intValue());
record.setTraceRefType(((Number) converter.get(TRACE_REF_TYPE)).intValue());
record.setRelatedTraceId((String) converter.get(RELATED_TRACE_ID));
record.setTraceSegmentId((String) converter.get(TRACE_SEGMENT_ID));
record.setTraceSpanId((String) converter.get(TRACE_SPAN_ID));
record.setDataBinary(converter.getBytes(DATA_BINARY));
record.setTimestamp(((Number) converter.get(TIMESTAMP)).longValue());
return record;
}
@Override
public void entity2Storage(SpanAttachedEventRecord entity, Convert2Storage converter) {
converter.accept(START_TIME_SECOND, entity.getStartTimeSecond());
converter.accept(START_TIME_NANOS, entity.getStartTimeNanos());
converter.accept(EVENT, entity.getEvent());
converter.accept(END_TIME_SECOND, entity.getEndTimeSecond());
converter.accept(END_TIME_NANOS, entity.getEndTimeNanos());
converter.accept(TRACE_REF_TYPE, entity.getTraceRefType());
converter.accept(RELATED_TRACE_ID, entity.getRelatedTraceId());
converter.accept(TRACE_SEGMENT_ID, entity.getTraceSegmentId());
converter.accept(TRACE_SPAN_ID, entity.getTraceSpanId());
converter.accept(DATA_BINARY, entity.getDataBinary());
converter.accept(TIMESTAMP, entity.getTimestamp());
}
}
}