com.edduarte.vokter.document.Document.java Source code

Java tutorial

Introduction

Here is the source code for com.edduarte.vokter.document.Document.java

Source

/*
 * Copyright 2015 Eduardo Duarte
 *
 * Licensed 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.edduarte.vokter.document;

import com.edduarte.vokter.util.Constants;
import com.mongodb.BasicDBObject;
import com.mongodb.BulkWriteOperation;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;

/**
 * Simple structure that holds a document current snapshot and associates
 * it with an url.
 *
 * @author Eduardo Duarte (<a href="mailto:hello@edduarte.com">hello@edduarte.com</a>)
 * @version 1.3.2
 * @since 1.0.0
 */
public final class Document extends BasicDBObject implements Serializable {

    public static final String ID = "id";

    public static final String URL = "url";

    public static final String ORIGINAL_CONTENT = "original_content";

    private static final long serialVersionUID = 1L;

    private static final int BOUND_INDEX = 4;

    private transient final DBCollection occCollection;

    Document(DB occurrencesDB, String url, String originalContent) {
        super(ID, Constants.bytesToHex(Constants.generateRandomBytes()));
        append(URL, url);
        append(ORIGINAL_CONTENT, originalContent);
        occCollection = occurrencesDB.getCollection(getUrl().hashCode() + getString(ID));
    }

    Document(DB occurrencesDB, BasicDBObject dbObject) {
        super(dbObject);
        occCollection = occurrencesDB.getCollection(getUrl().hashCode() + getString(ID));
    }

    public void addOccurrence(Occurrence occurrence) {
        occCollection.insert(occurrence);
    }

    public void addOccurrences(Stream<Occurrence> occurrencesStream) {
        addOccurrences(occurrencesStream.iterator());
    }

    public void addOccurrences(Iterator<Occurrence> occurrencesIt) {
        if (!occurrencesIt.hasNext()) {
            return;
        }
        BulkWriteOperation builder = occCollection.initializeUnorderedBulkOperation();
        while (occurrencesIt.hasNext()) {
            builder.insert(occurrencesIt.next());
        }
        builder.execute();
        builder = null;
    }

    public Occurrence getOccurrence(String text, int wordCount) {
        if (text.isEmpty()) {
            return null;
        }
        int lowerBound = wordCount - BOUND_INDEX;
        int upperBound = wordCount + BOUND_INDEX;

        BasicDBObject boundQuery = new BasicDBObject("$gt", lowerBound).append("$lt", upperBound);
        BasicDBObject queriedObject = (BasicDBObject) occCollection
                .findOne(new BasicDBObject(Occurrence.TEXT, text).append(Occurrence.WORD_COUNT, boundQuery));
        return queriedObject != null ? new Occurrence(queriedObject) : null;
    }

    public List<Occurrence> getAllOccurrences(String occurrencesText) {
        if (occurrencesText.isEmpty()) {
            return null;
        }
        DBCursor cursor = occCollection.find(new BasicDBObject(Occurrence.TEXT, occurrencesText));
        List<Occurrence> list = new ArrayList<>();
        while (cursor.hasNext()) {
            BasicDBObject obj = (BasicDBObject) cursor.next();
            list.add(new Occurrence(obj));
        }
        cursor.close();
        return list;
    }

    public String getUrl() {
        return getString(URL);
    }

    public String getOriginalContent() {
        return getString(ORIGINAL_CONTENT);
    }

    /**
     * Converts a cluster of occurrences associated with a document into a String,
     * where each occurrences is separated by a whitespace.
     */
    @SuppressWarnings("unchecked")
    public String getProcessedContent() {
        DBCursor cursor = occCollection.find();
        return StreamSupport.stream(cursor.spliterator(), false).map(Occurrence::new).map(Occurrence::toString)
                .collect(Collectors.joining(" "));
    }

    @Override
    public boolean equals(Object o) {
        if (this == o)
            return true;
        if (o == null || getClass() != o.getClass())
            return false;
        if (!super.equals(o))
            return false;

        Document that = (Document) o;
        return this.getUrl().equalsIgnoreCase(that.getUrl());
    }

    @Override
    public int hashCode() {
        return getUrl().hashCode();
    }

    @Override
    public String toString() {
        return getUrl();
    }

    void destroy() {
        occCollection.drop();
    }
}