Home Manual Reference Source Test Repository

src/searching/builder/DatasetSearchBuilder.js

'use strict';

import SearchBuilder from './SearchBuilder';
import FieldFinder from '../../util/searchingFields/FieldFinder';
import WPSearch from '../WPSearch';
export const BASE_URL = 'datasets';

/**
 * Defined a search over Executions	
 * @example ogapi.datasetSearchBuilder(organization, datasetId)
 */
export default class DatasetSearchBuilder extends SearchBuilder {
    /**
     *	@param {!InternalOpenGateAPI} parent - Instance of our InternalOpenGateAPI
     */
    constructor(parent, organization, dataset){
        super(parent, {}, new FieldFinder(parent, BASE_URL, {organization: organization, dataset: dataset}))
        this._url = BASE_URL + '/provision/organizations/' + organization + '/' + dataset + '/data'
    }
    
    /**
     * The search request will have this group by 
     * @example
     * @param {!(object)} group 
     * @return {DatasetSearchBuilder} 
     */
    group(group) {
        this._builderParams.group = (group || {});
        return this;
    }


    /**
     * The search request will have this filter 
     * @example
     *  ogapi.datasetSearchBuilder(organization, datasetId).select(
     *      ogapi.newSelectBuilder().add(SE.element("provision.device.identifier", ["value"], "id"), SE.add("device.temperature.value", ["value"]))
     *  ) // Setting SelectBuilder
     *  ogapi.datasetSearchBuilder(organization, datasetId).select({ "elements": [{"name": "provision.device.identifier",
     *		"fields": [{"field": "value","alias": "identifier"}]},
     *      {"name": "device.temperature.value","fields": [{"field": "value","alias": "identifier"}]}]
     *   }) //Custom select
     * @param {!(SelectBuilder|object)} select
     * @return {DatasetSearchBuilder} 
     */
    select(select) {
        this._builderParams.select = (select || []);
        return this;
    }

    /**
     * Build a instance of Search 
     *
     * @example
     *  ogapi.datasetSearchBuilder(organization, datasetId).build()
     * @throws {SearchBuilderError} Throw error on url build
     * @return {Search} 
     */
     build() {
        return new WPSearch(this._parent,
            this._buildUrl(),
            this._buildFilter(),
            this._buildLimit(),
            this._buildSort(),
            this._buildGroup(),
            this._buildSelect(),
            this._builderParams.timeout,
            this._urlParams);
    }
}