// Copyright 2017 The Nomulus Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package google.registry.mapreduce.inputs; import com.google.appengine.tools.mapreduce.Input; import com.google.appengine.tools.mapreduce.InputReader; import com.google.common.collect.ImmutableList; import com.googlecode.objectify.Key; import google.registry.model.index.EppResourceIndex; import google.registry.model.index.EppResourceIndexBucket; import java.util.List; /** Base class for {@link Input} classes that map over {@link EppResourceIndex}. */ abstract class EppResourceBaseInput extends Input { private static final long serialVersionUID = -6681886718929462122L; @Override public List> createReaders() { ImmutableList.Builder> readers = new ImmutableList.Builder<>(); for (Key bucketKey : EppResourceIndexBucket.getAllBuckets()) { readers.add(bucketToReader(bucketKey)); } return readers.build(); } /** Creates a reader that returns the resources under a bucket. */ protected abstract InputReader bucketToReader(Key bucketKey); }