/*******************************************************************************
* Copyright French Prime minister Office/SGMAP/DINSIC/Vitam Program (2015-2019)
*
* contact.vitam@culture.gouv.fr
*
* This software is a computer program whose purpose is to implement a digital archiving back-office system managing
* high volumetry securely and efficiently.
*
* This software is governed by the CeCILL 2.1 license under French law and abiding by the rules of distribution of free
* software. You can use, modify and/ or redistribute the software under the terms of the CeCILL 2.1 license as
* circulated by CEA, CNRS and INRIA at the following URL "http://www.cecill.info".
*
* As a counterpart to the access to the source code and rights to copy, modify and redistribute granted by the license,
* users are provided only with a limited warranty and the software's author, the holder of the economic rights, and the
* successive licensors have only limited liability.
*
* In this respect, the user's attention is drawn to the risks associated with loading, using, modifying and/or
* developing or reproducing the software by the user in light of its specific status of free software, that may mean
* that it is complicated to manipulate, and that also therefore means that it is reserved for developers and
* experienced professionals having in-depth computer knowledge. Users are therefore encouraged to load and test the
* software's suitability as regards their requirements in conditions enabling the security of their systems and/or data
* to be ensured and, more generally, to use and operate it in the same conditions as regards security.
*
* The fact that you are presently reading this means that you have had knowledge of the CeCILL 2.1 license and that you
* accept its terms.
*******************************************************************************/
package fr.gouv.vitam.common.database.parser.query;
import com.fasterxml.jackson.databind.JsonNode;
import fr.gouv.vitam.common.database.builder.query.NopQuery;
import fr.gouv.vitam.common.database.builder.query.QueryHelper;
import fr.gouv.vitam.common.database.builder.request.configuration.BuilderToken.QUERY;
import fr.gouv.vitam.common.database.builder.request.exception.InvalidCreateOperationException;
import fr.gouv.vitam.common.database.parser.request.adapter.VarNameAdapter;
import fr.gouv.vitam.common.exception.InvalidParseOperationException;
/**
* Query from Parser Helper
*
*/
public class QueryParserHelper extends QueryHelper {
protected QueryParserHelper() {}
/**
*
* @param array primary list of path in the future PathQuery
* @param adapter VarNameAdapter
* @return a PathQuery
*/
public static final PathQuery path(final JsonNode array, final VarNameAdapter adapter) {
return new PathQuery(QUERY.PATH, array, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using EQ comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery eq(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.EQ, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using NE comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery ne(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.NE, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using LT (less than) comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery lt(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.LT, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using LTE (less than or equal) comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery lte(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.LTE, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using GT (greater than) comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery gt(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.GT, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using GTE (greater than or equal) comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery gte(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.GTE, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a CompareQuery using SIZE comparator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final CompareQuery size(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new CompareQuery(QUERY.SIZE, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return an ExistsQuery
* @throws InvalidCreateOperationException using Exists operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final ExistsQuery exists(final JsonNode command, final VarNameAdapter adapter)
throws InvalidCreateOperationException, InvalidParseOperationException {
return new ExistsQuery(QUERY.EXISTS, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return an ExistsQuery using Missing operator
* @throws InvalidCreateOperationException using Exists operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final ExistsQuery missing(final JsonNode command, final VarNameAdapter adapter)
throws InvalidCreateOperationException, InvalidParseOperationException {
return new ExistsQuery(QUERY.MISSING, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return an ExistsQuery using isNull operator
* @throws InvalidCreateOperationException using Exists operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final ExistsQuery isNull(final JsonNode command, final VarNameAdapter adapter)
throws InvalidCreateOperationException, InvalidParseOperationException {
return new ExistsQuery(QUERY.ISNULL, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return an InQuery using IN operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final InQuery in(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new InQuery(QUERY.IN, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return an InQuery using NIN (not in) operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final InQuery nin(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new InQuery(QUERY.NIN, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MatchQuery using MATCH operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MatchQuery match(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MatchQuery(QUERY.MATCH, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MatchQuery using MATCH_PHRASE operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MatchQuery matchPhrase(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MatchQuery(QUERY.MATCH_PHRASE, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MatchQuery using MATCH_PHRASE_PREFIX operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MatchQuery matchPhrasePrefix(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MatchQuery(QUERY.MATCH_PHRASE_PREFIX, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MatchQuery using PREFIX operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MatchQuery prefix(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MatchQuery(QUERY.PREFIX, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a SearchQuery using REGEX operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final SearchQuery regex(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new SearchQuery(QUERY.REGEX, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a SearchQuery using SEARCH operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final SearchQuery search(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new SearchQuery(QUERY.SEARCH, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a TermQuery
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final TermQuery term(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new TermQuery(QUERY.TERM, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a WildcardQuery
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final WildcardQuery wildcard(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new WildcardQuery(QUERY.WILDCARD, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MltQuery using a FLT (fuzzy like this) operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MltQuery flt(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MltQuery(QUERY.FLT, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a MltQuery using a MLT (more like this) operator
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final MltQuery mlt(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new MltQuery(QUERY.MLT, command, adapter);
}
/**
*
* @param command JsonNode
* @param adapter VarNameAdapter
* @return a RangeQuery
* @throws InvalidParseOperationException if could not parse to JSON
*/
public static final RangeQuery range(final JsonNode command, final VarNameAdapter adapter)
throws InvalidParseOperationException {
return new RangeQuery(QUERY.RANGE, command, adapter);
}
/**
* Constructs a null operation (nop) query, meaning there is no 'where' demand.
*
* @return a NopQuery
* @throws InvalidCreateOperationException using NOP operator
*/
public static final NopQuery nop() throws InvalidCreateOperationException {
return new NopQuery();
}
}