All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dataloader.BatchLoader Maven / Gradle / Ivy

There is a newer version: 2022-09-12T23-25-35-08559ba
Show newest version
/*
 * Copyright (c) 2016 The original author or authors
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Apache License v2.0 which accompanies this distribution.
 *
 *      The Eclipse Public License is available at
 *      http://www.eclipse.org/legal/epl-v10.html
 *
 *      The Apache License v2.0 is available at
 *      http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */

package org.dataloader;

import java.util.List;
import java.util.concurrent.CompletionStage;

/**
 * A function that is invoked for batch loading a list of data values indicated by the provided list of keys. The
 * function returns a promise of a list of results of individual load requests.
 *
 * There are a few constraints that must be upheld:
 * 
    *
  • The list of values must be the same size as the list of keys.
  • *
  • Each index in the list of values must correspond to the same index in the list of keys.
  • *
* * For example, if your batch function was provided the list of keys: * *
 *  [
 *      2, 9, 6, 1
 *  ]
 * 
* * and loading from a back-end service returned this list of values: * *
 *  [
 *      { id: 9, name: 'Chicago' },
 *      { id: 1, name: 'New York' },
 *      { id: 2, name: 'San Francisco' },
 *  ]
 * 
* * then the batch loader function contract has been broken. * * The back-end service returned results in a different order than we requested, likely because it was more efficient for it to * do so. Also, it omitted a result for key 6, which we may interpret as no value existing for that key. * * To uphold the constraints of the batch function, it must return an List of values the same length as * the List of keys, and re-order them to ensure each index aligns with the original keys [ 2, 9, 6, 1 ]: * *
 *  [
 *      { id: 2, name: 'San Francisco' },
 *      { id: 9, name: 'Chicago' },
 *      null,
 *      { id: 1, name: 'New York' }
 * ]
 * 
* * @param type parameter indicating the type of keys to use for data load requests. * @param type parameter indicating the type of values returned * * @author Arnold Schrijver * @author Brad Baker */ @FunctionalInterface public interface BatchLoader { /** * Called to batch load the provided keys and return a promise to a list of values * * @param keys the collection of keys to load * * @return a promise of the values for those keys */ CompletionStage> load(List keys); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy