Package org.apache.druid.data.input.impl
Class HttpInputSource
- java.lang.Object
-
- org.apache.druid.data.input.AbstractInputSource
-
- org.apache.druid.data.input.impl.HttpInputSource
-
- All Implemented Interfaces:
SplittableInputSource<URI>,SystemFieldInputSource,InputSource
public class HttpInputSource extends AbstractInputSource implements SplittableInputSource<URI>, SystemFieldInputSource
-
-
Field Summary
Fields Modifier and Type Field Description static StringTYPE_KEY-
Fields inherited from interface org.apache.druid.data.input.InputSource
TYPE_PROPERTY
-
Fields inherited from interface org.apache.druid.data.input.impl.SplittableInputSource
DEFAULT_SPLIT_HINT_SPEC
-
Fields inherited from interface org.apache.druid.data.input.impl.systemfield.SystemFieldInputSource
SYSTEM_FIELDS_PROPERTY
-
-
Constructor Summary
Constructors Constructor Description HttpInputSource(List<URI> uris, String httpAuthenticationUsername, PasswordProvider httpAuthenticationPasswordProvider, SystemFields systemFields, Map<String,String> requestHeaders, HttpInputSourceConfig config)
-
Method Summary
-
Methods inherited from class org.apache.druid.data.input.AbstractInputSource
fixedFormatReader, reader
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.druid.data.input.InputSource
reader
-
Methods inherited from interface org.apache.druid.data.input.impl.SplittableInputSource
getSplitHintSpecOrDefault, isSplittable
-
-
-
-
Field Detail
-
TYPE_KEY
public static final String TYPE_KEY
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
HttpInputSource
public HttpInputSource(List<URI> uris, @Nullable String httpAuthenticationUsername, @Nullable PasswordProvider httpAuthenticationPasswordProvider, @Nullable SystemFields systemFields, @Nullable Map<String,String> requestHeaders, HttpInputSourceConfig config)
-
-
Method Detail
-
throwIfInvalidProtocols
public static void throwIfInvalidProtocols(HttpInputSourceConfig config, List<URI> uris)
-
throwIfForbiddenHeaders
public static void throwIfForbiddenHeaders(HttpInputSourceConfig config, Map<String,String> requestHeaders)
-
getTypes
@Nonnull public Set<String> getTypes()
Description copied from interface:InputSourceThe types of input sources uses. A set is returned here, as some InputSource implementation allow for combining of multiple input sources.- Specified by:
getTypesin interfaceInputSource- Returns:
- The types of input sources uses
-
getConfiguredSystemFields
public Set<SystemField> getConfiguredSystemFields()
Description copied from interface:SystemFieldInputSourceSystem fields that this input source is configured to return. This is not the same set thatSystemFieldInputSource.getSystemFieldValue(InputEntity, SystemField)returns nonnull for. For example, if aLocalInputSourceis configured to returnSystemField.BUCKETthen it will show up in this list, even though its value is always null. For another example in a different direction, if aLocalInputSourceis *not* configured to returnSystemField.URI, then it will *not* show up in this list, even though its value fromSystemFieldInputSource.getSystemFieldValue(InputEntity, SystemField)would be nonnull.- Specified by:
getConfiguredSystemFieldsin interfaceSystemFieldInputSource
-
getHttpAuthenticationPasswordProvider
@Nullable public PasswordProvider getHttpAuthenticationPasswordProvider()
-
createSplits
public Stream<InputSplit<URI>> createSplits(InputFormat inputFormat, @Nullable SplitHintSpec splitHintSpec)
Description copied from interface:SplittableInputSourceCreates aStreamofInputSplits. The returned stream is supposed to be evaluated lazily to avoid consuming too much memory. Note that this interface also hasSplittableInputSource.estimateNumSplits(org.apache.druid.data.input.InputFormat, org.apache.druid.data.input.SplitHintSpec)which is related to this method. The implementations should be careful to NOT cache the created splits in memory. Implementations can considerInputFormat.isSplittable()andSplitHintSpecto create splits in the same way withSplittableInputSource.estimateNumSplits(org.apache.druid.data.input.InputFormat, org.apache.druid.data.input.SplitHintSpec).- Specified by:
createSplitsin interfaceSplittableInputSource<URI>
-
estimateNumSplits
public int estimateNumSplits(InputFormat inputFormat, @Nullable SplitHintSpec splitHintSpec)
Description copied from interface:SplittableInputSourceReturns an estimated total number of splits to be created viaSplittableInputSource.createSplits(org.apache.druid.data.input.InputFormat, org.apache.druid.data.input.SplitHintSpec). The estimated number of splits doesn't have to be accurate and can be different from the actual number of InputSplits returned fromSplittableInputSource.createSplits(org.apache.druid.data.input.InputFormat, org.apache.druid.data.input.SplitHintSpec). This will be used to estimate the progress of a phase in parallel indexing. See TaskMonitor for more details of the progress estimation. This method can be expensive if an implementation iterates all directories or whatever substructure to find all input entities. Implementations can considerInputFormat.isSplittable()andSplitHintSpecto find splits in the same way withSplittableInputSource.createSplits(org.apache.druid.data.input.InputFormat, org.apache.druid.data.input.SplitHintSpec).- Specified by:
estimateNumSplitsin interfaceSplittableInputSource<URI>
-
withSplit
public SplittableInputSource<URI> withSplit(InputSplit<URI> split)
Description copied from interface:SplittableInputSourceHelper method for ParallelIndexSupervisorTask. Most of implementations can simply create a new instance with the given split.- Specified by:
withSplitin interfaceSplittableInputSource<URI>
-
getSystemFieldValue
public Object getSystemFieldValue(InputEntity entity, SystemField field)
Description copied from interface:SystemFieldInputSourceCompute the value of a system field for a particularInputEntity.- Specified by:
getSystemFieldValuein interfaceSystemFieldInputSource
-
formattableReader
protected InputSourceReader formattableReader(InputRowSchema inputRowSchema, InputFormat inputFormat, @Nullable File temporaryDirectory)
- Overrides:
formattableReaderin classAbstractInputSource
-
needsFormat
public boolean needsFormat()
Description copied from interface:InputSourceReturns true if this inputSource supports differentInputFormats. Some inputSources such asLocalInputSourcecan store files of any format. These storage types require anInputFormatto be passed so thatInputSourceReadercan parse data properly. However, some storage types have a fixed format. For example, druid inputSource always reads segments. These inputSources should return false for this method.- Specified by:
needsFormatin interfaceInputSource
-
-