Search in sources :

Example 6 with HBaseRow

use of org.apache.camel.component.hbase.model.HBaseRow in project camel by apache.

the class HBaseProducer method scanCells.

/**
     * Performs an HBase {@link Get} on a specific row, using a collection of values (family/column/value pairs).
     * The result is <p>the most recent entry</p> for each column.
     */
private List<HBaseRow> scanCells(Table table, HBaseRow model, String start, String stop, Integer maxRowScan, List<Filter> filters) throws Exception {
    List<HBaseRow> rowSet = new LinkedList<>();
    HBaseRow startRow = new HBaseRow(model.getCells());
    startRow.setId(start);
    Scan scan;
    if (start != null) {
        scan = new Scan(Bytes.toBytes(start));
    } else {
        scan = new Scan();
    }
    if (ObjectHelper.isNotEmpty(stop)) {
        scan.setStopRow(Bytes.toBytes(stop));
    }
    if (filters != null && !filters.isEmpty()) {
        for (int i = 0; i < filters.size(); i++) {
            ((ModelAwareFilter<?>) filters.get(i)).apply(endpoint.getCamelContext(), model);
            scan.setFilter(new FilterList(FilterList.Operator.MUST_PASS_ALL, ((ModelAwareFilter<?>) filters.get(i)).getFilteredList()));
        }
    }
    Set<HBaseCell> cellModels = model.getCells();
    for (HBaseCell cellModel : cellModels) {
        String family = cellModel.getFamily();
        String column = cellModel.getQualifier();
        if (ObjectHelper.isNotEmpty(family) && ObjectHelper.isNotEmpty(column)) {
            scan.addColumn(HBaseHelper.getHBaseFieldAsBytes(family), HBaseHelper.getHBaseFieldAsBytes(column));
        }
    }
    ResultScanner resultScanner = table.getScanner(scan);
    int count = 0;
    Result result = resultScanner.next();
    while (result != null && count < maxRowScan) {
        HBaseRow resultRow = new HBaseRow();
        resultRow.setId(endpoint.getCamelContext().getTypeConverter().convertTo(model.getRowType(), result.getRow()));
        resultRow.setTimestamp(result.rawCells()[0].getTimestamp());
        cellModels = model.getCells();
        for (HBaseCell modelCell : cellModels) {
            HBaseCell resultCell = new HBaseCell();
            String family = modelCell.getFamily();
            String column = modelCell.getQualifier();
            resultRow.setId(endpoint.getCamelContext().getTypeConverter().convertTo(model.getRowType(), result.getRow()));
            resultCell.setValue(endpoint.getCamelContext().getTypeConverter().convertTo(modelCell.getValueType(), result.getValue(HBaseHelper.getHBaseFieldAsBytes(family), HBaseHelper.getHBaseFieldAsBytes(column))));
            resultCell.setFamily(modelCell.getFamily());
            resultCell.setQualifier(modelCell.getQualifier());
            Cell cell = result.getColumnLatestCell(HBaseHelper.getHBaseFieldAsBytes(family), HBaseHelper.getHBaseFieldAsBytes(column));
            if (cell != null) {
                resultCell.setTimestamp(cell.getTimestamp());
            }
            resultRow.getCells().add(resultCell);
        }
        rowSet.add(resultRow);
        count++;
        result = resultScanner.next();
    }
    return rowSet;
}
Also used : ResultScanner(org.apache.hadoop.hbase.client.ResultScanner) FilterList(org.apache.hadoop.hbase.filter.FilterList) LinkedList(java.util.LinkedList) HBaseCell(org.apache.camel.component.hbase.model.HBaseCell) Result(org.apache.hadoop.hbase.client.Result) HBaseRow(org.apache.camel.component.hbase.model.HBaseRow) ModelAwareFilter(org.apache.camel.component.hbase.filters.ModelAwareFilter) Scan(org.apache.hadoop.hbase.client.Scan) HBaseCell(org.apache.camel.component.hbase.model.HBaseCell) Cell(org.apache.hadoop.hbase.Cell)

Example 7 with HBaseRow

use of org.apache.camel.component.hbase.model.HBaseRow in project camel by apache.

the class HeaderMappingStrategy method applyScanResults.

/**
     * Applies the cells to the {@link org.apache.camel.Exchange}.
     */
public void applyScanResults(Message message, HBaseData data) {
    message.setHeaders(message.getExchange().getIn().getHeaders());
    int index = 1;
    if (data == null || data.getRows() == null) {
        return;
    }
    for (HBaseRow hRow : data.getRows()) {
        Set<HBaseCell> cells = hRow.getCells();
        for (HBaseCell cell : cells) {
            message.setHeader(HBaseAttribute.HBASE_ROW_ID.asHeader(index), hRow.getId());
            message.setHeader(HBaseAttribute.HBASE_FAMILY.asHeader(index), cell.getFamily());
            message.setHeader(HBaseAttribute.HBASE_QUALIFIER.asHeader(index), cell.getQualifier());
            message.setHeader(HBaseAttribute.HBASE_VALUE.asHeader(index), cell.getValue());
        }
        index++;
    }
}
Also used : HBaseRow(org.apache.camel.component.hbase.model.HBaseRow) HBaseCell(org.apache.camel.component.hbase.model.HBaseCell)

Example 8 with HBaseRow

use of org.apache.camel.component.hbase.model.HBaseRow in project camel by apache.

the class HeaderMappingStrategy method resolveModel.

/**
     * Resolves the cells that the {@link org.apache.camel.Exchange} refers to.
     */
@Override
public HBaseData resolveModel(Message message) {
    int index = 1;
    HBaseData data = new HBaseData();
    //We use a LinkedHashMap to preserve the order.
    Map<Object, HBaseRow> rows = new LinkedHashMap<>();
    HBaseRow hRow = new HBaseRow();
    while (hRow != null) {
        hRow = resolveRow(message, index++);
        if (hRow != null) {
            if (rows.containsKey(hRow.getId())) {
                rows.get(hRow.getId()).getCells().addAll(hRow.getCells());
            } else {
                rows.put(hRow.getId(), hRow);
            }
        }
    }
    for (Map.Entry<Object, HBaseRow> rowEntry : rows.entrySet()) {
        data.getRows().add(rowEntry.getValue());
    }
    return data;
}
Also used : HBaseData(org.apache.camel.component.hbase.model.HBaseData) HBaseRow(org.apache.camel.component.hbase.model.HBaseRow) LinkedHashMap(java.util.LinkedHashMap) Map(java.util.Map) LinkedHashMap(java.util.LinkedHashMap)

Example 9 with HBaseRow

use of org.apache.camel.component.hbase.model.HBaseRow in project camel by apache.

the class HeaderMappingStrategy method applyGetResults.

/**
     * Applies the cells to the {@link org.apache.camel.Exchange}.
     */
public void applyGetResults(Message message, HBaseData data) {
    message.setHeaders(message.getExchange().getIn().getHeaders());
    int index = 1;
    if (data == null || data.getRows() == null) {
        return;
    }
    for (HBaseRow hRow : data.getRows()) {
        if (hRow.getId() != null) {
            Set<HBaseCell> cells = hRow.getCells();
            for (HBaseCell cell : cells) {
                message.setHeader(HBaseAttribute.HBASE_VALUE.asHeader(index++), getValueForColumn(cells, cell.getFamily(), cell.getQualifier()));
            }
        }
    }
}
Also used : HBaseRow(org.apache.camel.component.hbase.model.HBaseRow) HBaseCell(org.apache.camel.component.hbase.model.HBaseCell)

Aggregations

HBaseRow (org.apache.camel.component.hbase.model.HBaseRow)9 HBaseCell (org.apache.camel.component.hbase.model.HBaseCell)7 LinkedList (java.util.LinkedList)4 HBaseData (org.apache.camel.component.hbase.model.HBaseData)3 Cell (org.apache.hadoop.hbase.Cell)3 Result (org.apache.hadoop.hbase.client.Result)3 CellMappingStrategy (org.apache.camel.component.hbase.mapping.CellMappingStrategy)2 ResultScanner (org.apache.hadoop.hbase.client.ResultScanner)2 Scan (org.apache.hadoop.hbase.client.Scan)2 Table (org.apache.hadoop.hbase.client.Table)2 FilterList (org.apache.hadoop.hbase.filter.FilterList)2 LinkedHashMap (java.util.LinkedHashMap)1 Map (java.util.Map)1 Exchange (org.apache.camel.Exchange)1 ModelAwareFilter (org.apache.camel.component.hbase.filters.ModelAwareFilter)1 DefaultEndpoint (org.apache.camel.impl.DefaultEndpoint)1 UriEndpoint (org.apache.camel.spi.UriEndpoint)1 Delete (org.apache.hadoop.hbase.client.Delete)1 Get (org.apache.hadoop.hbase.client.Get)1 Put (org.apache.hadoop.hbase.client.Put)1