001package ca.uhn.fhir.rest.gclient;
002
003/*
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2016 University Health Network
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 * 
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 * 
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023import org.hl7.fhir.instance.model.api.IBaseResource;
024
025import ca.uhn.fhir.model.api.Bundle;
026
027public interface IUntypedQuery {
028
029        IQuery<Bundle> forAllResources();
030
031        IQuery<Bundle> forResource(String theResourceName);
032
033        IQuery<Bundle> forResource(Class<? extends IBaseResource> theClass);
034
035        /**
036         * Perform a search directly by URL. It is usually better to construct the URL using the {@link #forAllResources()}, {@link #forResource(Class)} etc, but sometimes it is useful to simply search by
037         * entering a search URL directly.
038         * 
039         * @param theSearchUrl
040         *           The URL to search for. Note that this URL may be complete (e.g. "http://example.com/base/Patient?name=foo") in which case the client's base URL will be ignored. Or it can be relative
041         *           (e.g. "Patient?name=foo") in which case the client's base URL will be used.
042         */
043        IQuery<Bundle> byUrl(String theSearchUrl);
044
045}