001package ca.uhn.fhir.rest.api.server.storage;
002
003/*-
004 * #%L
005 * HAPI FHIR - Server Framework
006 * %%
007 * Copyright (C) 2014 - 2022 Smile CDR, Inc.
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 ca.uhn.fhir.rest.api.server.RequestDetails;
024import org.springframework.batch.core.JobExecution;
025import org.springframework.batch.core.JobParametersInvalidException;
026
027import java.util.List;
028
029public interface IMultiUrlJobSubmitter {
030        /**
031         * @param theBatchSize     For each pass, when synchronously searching for resources, limit the number of matching resources to this number
032         * @param theUrlsToProcess A list of strings of the form "/Patient?active=true"
033         * @return The Spring Batch JobExecution that was started to run this batch job
034         * @throws JobParametersInvalidException
035         */
036        JobExecution submitJob(Integer theBatchSize, List<String> theUrlsToProcess, RequestDetails theRequest) throws JobParametersInvalidException;
037}