Search in sources :

Example 11 with RecordField

use of org.apache.nifi.repository.schema.RecordField in project nifi by apache.

the class LookupTableEventRecord method createContentClaimRecord.

private static Record createContentClaimRecord(final RecordSchema contentClaimSchema, final String container, final String section, final String identifier, final Long offset, final Long size) {
    if (container == null || section == null || identifier == null) {
        final Map<RecordField, Object> lookupValues = Collections.singletonMap(LookupTableEventRecordFields.NO_VALUE, EventFieldNames.NO_VALUE);
        final List<RecordField> noValueFields = Collections.singletonList(contentClaimSchema.getField(EventFieldNames.NO_VALUE));
        return new FieldMapRecord(lookupValues, new RecordSchema(noValueFields));
    }
    final Map<RecordField, Object> fieldValues = new HashMap<>();
    fieldValues.put(EventRecordFields.CONTENT_CLAIM_CONTAINER, container);
    fieldValues.put(EventRecordFields.CONTENT_CLAIM_SECTION, section);
    fieldValues.put(EventRecordFields.CONTENT_CLAIM_IDENTIFIER, identifier);
    fieldValues.put(EventRecordFields.CONTENT_CLAIM_OFFSET, offset);
    fieldValues.put(EventRecordFields.CONTENT_CLAIM_SIZE, size);
    final List<RecordField> explicitClaimFields = contentClaimSchema.getField(EventFieldNames.EXPLICIT_VALUE).getSubFields();
    final Record explicitClaimRecord = new FieldMapRecord(fieldValues, new RecordSchema(explicitClaimFields));
    return explicitClaimRecord;
}
Also used : FieldMapRecord(org.apache.nifi.repository.schema.FieldMapRecord) RecordField(org.apache.nifi.repository.schema.RecordField) HashMap(java.util.HashMap) Record(org.apache.nifi.repository.schema.Record) StandardProvenanceEventRecord(org.apache.nifi.provenance.StandardProvenanceEventRecord) FieldMapRecord(org.apache.nifi.repository.schema.FieldMapRecord) ProvenanceEventRecord(org.apache.nifi.provenance.ProvenanceEventRecord) RecordSchema(org.apache.nifi.repository.schema.RecordSchema)

Example 12 with RecordField

use of org.apache.nifi.repository.schema.RecordField in project nifi by apache.

the class LookupTableEventRecord method createExplicitSameOrNoneValue.

private NamedValue createExplicitSameOrNoneValue(final Record newValue, final Record oldValue, final Supplier<Record> recordSupplier) {
    if (newValue == null || EventFieldNames.NO_VALUE.equals(newValue.getSchema().getFields().get(0).getFieldName())) {
        final Map<RecordField, Object> lookupValues = Collections.singletonMap(LookupTableEventRecordFields.NO_VALUE, EventFieldNames.NO_VALUE);
        final Record record = new FieldMapRecord(lookupValues, LookupTableEventSchema.NO_VALUE_SCHEMA);
        final NamedValue namedValue = new NamedValue(EventFieldNames.NO_VALUE, record);
        return namedValue;
    } else if (newValue.equals(oldValue)) {
        final Map<RecordField, Object> lookupValues = Collections.singletonMap(LookupTableEventRecordFields.UNCHANGED_VALUE, EventFieldNames.UNCHANGED_VALUE);
        final Record record = new FieldMapRecord(lookupValues, LookupTableEventSchema.UNCHANGED_VALUE_SCHEMA);
        final NamedValue namedValue = new NamedValue(EventFieldNames.UNCHANGED_VALUE, record);
        return namedValue;
    }
    final Record record = recordSupplier.get();
    final NamedValue namedValue = new NamedValue(EventFieldNames.EXPLICIT_VALUE, record);
    return namedValue;
}
Also used : FieldMapRecord(org.apache.nifi.repository.schema.FieldMapRecord) RecordField(org.apache.nifi.repository.schema.RecordField) Record(org.apache.nifi.repository.schema.Record) StandardProvenanceEventRecord(org.apache.nifi.provenance.StandardProvenanceEventRecord) FieldMapRecord(org.apache.nifi.repository.schema.FieldMapRecord) ProvenanceEventRecord(org.apache.nifi.provenance.ProvenanceEventRecord) NamedValue(org.apache.nifi.repository.schema.NamedValue) HashMap(java.util.HashMap) Map(java.util.Map)

Aggregations

RecordField (org.apache.nifi.repository.schema.RecordField)12 RecordSchema (org.apache.nifi.repository.schema.RecordSchema)10 ArrayList (java.util.ArrayList)8 FieldMapRecord (org.apache.nifi.repository.schema.FieldMapRecord)7 Record (org.apache.nifi.repository.schema.Record)7 SimpleRecordField (org.apache.nifi.repository.schema.SimpleRecordField)6 HashMap (java.util.HashMap)5 ByteArrayOutputStream (java.io.ByteArrayOutputStream)4 DataOutputStream (java.io.DataOutputStream)4 Map (java.util.Map)4 EventRecord (org.apache.nifi.provenance.schema.EventRecord)4 NopTocWriter (org.apache.nifi.provenance.toc.NopTocWriter)4 StandardTocWriter (org.apache.nifi.provenance.toc.StandardTocWriter)4 TocWriter (org.apache.nifi.provenance.toc.TocWriter)4 FileInputStream (java.io.FileInputStream)3 IOException (java.io.IOException)3 InputStream (java.io.InputStream)3 OutputStream (java.io.OutputStream)3 List (java.util.List)3 RecordReader (org.apache.nifi.provenance.serialization.RecordReader)3