mirror of https://github.com/apache/druid.git
add apidoc/etc
This commit is contained in:
parent
9ac26e3a89
commit
df42245685
|
@ -21,15 +21,13 @@ package org.apache.druid.sql.hook;
|
||||||
|
|
||||||
import com.google.errorprone.annotations.Immutable;
|
import com.google.errorprone.annotations.Immutable;
|
||||||
import org.apache.calcite.rel.RelNode;
|
import org.apache.calcite.rel.RelNode;
|
||||||
import org.apache.druid.annotations.SuppressFBWarnings;
|
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for hooks that can be invoked by {@link DruidHookDispatcher}.
|
||||||
|
*
|
||||||
|
* HookKey should be added at every place a new hook is needed.
|
||||||
|
*/
|
||||||
@FunctionalInterface
|
@FunctionalInterface
|
||||||
public interface DruidHook<T>
|
public interface DruidHook<T>
|
||||||
{
|
{
|
||||||
|
@ -74,41 +72,4 @@ public interface DruidHook<T>
|
||||||
}
|
}
|
||||||
|
|
||||||
void invoke(HookKey<T> key, T object);
|
void invoke(HookKey<T> key, T object);
|
||||||
|
|
||||||
@SuppressFBWarnings({"MS_OOI_PKGPROTECT"})
|
|
||||||
Map<HookKey<?>, List<DruidHook<?>>> GLOBAL = new HashMap<>();
|
|
||||||
|
|
||||||
static void register1(HookKey<?> label, DruidHook<?> hook)
|
|
||||||
{
|
|
||||||
GLOBAL.computeIfAbsent(label, k -> new ArrayList<>()).add(hook);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void unregister1(HookKey<?> key, DruidHook<?> hook)
|
|
||||||
{
|
|
||||||
GLOBAL.get(key).remove(hook);
|
|
||||||
}
|
|
||||||
|
|
||||||
static <T> Closeable withHook1(HookKey<T> key, DruidHook<T> hook)
|
|
||||||
{
|
|
||||||
register1(key, hook);
|
|
||||||
return new Closeable()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void close()
|
|
||||||
{
|
|
||||||
unregister1(key, hook);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings({"rawtypes", "unchecked"})
|
|
||||||
static <T> void dispatch12(HookKey<T> key, T object)
|
|
||||||
{
|
|
||||||
List<DruidHook<?>> hooks = GLOBAL.get(key);
|
|
||||||
if (hooks != null) {
|
|
||||||
for (DruidHook hook : hooks) {
|
|
||||||
hook.invoke(key, object);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,24 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one
|
|
||||||
* or more contributor license agreements. See the NOTICE file
|
|
||||||
* distributed with this work for additional information
|
|
||||||
* regarding copyright ownership. The ASF licenses this file
|
|
||||||
* to you 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 org.apache.druid.sql.hook;
|
|
||||||
|
|
||||||
public interface DruidHook2<T>
|
|
||||||
{
|
|
||||||
}
|
|
|
@ -21,6 +21,8 @@ package org.apache.druid.sql.hook;
|
||||||
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import org.apache.druid.guice.LazySingleton;
|
import org.apache.druid.guice.LazySingleton;
|
||||||
|
import org.apache.druid.quidem.DruidConnectionExtras;
|
||||||
|
import org.apache.druid.sql.calcite.planner.PlannerContext;
|
||||||
import org.apache.druid.sql.hook.DruidHook.HookKey;
|
import org.apache.druid.sql.hook.DruidHook.HookKey;
|
||||||
|
|
||||||
import java.io.Closeable;
|
import java.io.Closeable;
|
||||||
|
@ -29,24 +31,32 @@ import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dispatcher for Druid hooks.
|
||||||
|
*
|
||||||
|
* A single instance should live in the system and be used to dispatch hooks.
|
||||||
|
* Usual way to dispatch should be via
|
||||||
|
* {@link PlannerContext#dispatchHook(HookKey, Object)}. Access to this class is
|
||||||
|
* also possible thru {@link DruidConnectionExtras}.
|
||||||
|
*/
|
||||||
@LazySingleton
|
@LazySingleton
|
||||||
public class DruidHookDispatcher
|
public class DruidHookDispatcher
|
||||||
{
|
{
|
||||||
|
Map<HookKey<?>, List<DruidHook<?>>> hooks = new HashMap<>();
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public DruidHookDispatcher()
|
public DruidHookDispatcher()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<HookKey<?>, List<DruidHook<?>>> GLOBAL = new HashMap<>();
|
|
||||||
|
|
||||||
public void register(HookKey<?> label, DruidHook<?> hook)
|
public void register(HookKey<?> label, DruidHook<?> hook)
|
||||||
{
|
{
|
||||||
GLOBAL.computeIfAbsent(label, k -> new ArrayList<>()).add(hook);
|
hooks.computeIfAbsent(label, k -> new ArrayList<>()).add(hook);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void unregister(HookKey<?> key, DruidHook<?> hook)
|
public void unregister(HookKey<?> key, DruidHook<?> hook)
|
||||||
{
|
{
|
||||||
GLOBAL.get(key).remove(hook);
|
hooks.get(key).remove(hook);
|
||||||
}
|
}
|
||||||
|
|
||||||
public <T> Closeable withHook(HookKey<T> key, DruidHook<T> hook)
|
public <T> Closeable withHook(HookKey<T> key, DruidHook<T> hook)
|
||||||
|
@ -65,9 +75,9 @@ public class DruidHookDispatcher
|
||||||
@SuppressWarnings({"rawtypes", "unchecked"})
|
@SuppressWarnings({"rawtypes", "unchecked"})
|
||||||
public <T> void dispatch(HookKey<T> key, T object)
|
public <T> void dispatch(HookKey<T> key, T object)
|
||||||
{
|
{
|
||||||
List<DruidHook<?>> hooks = GLOBAL.get(key);
|
List<DruidHook<?>> currentHooks = hooks.get(key);
|
||||||
if (hooks != null) {
|
if (currentHooks != null) {
|
||||||
for (DruidHook hook : hooks) {
|
for (DruidHook hook : currentHooks) {
|
||||||
hook.invoke(key, object);
|
hook.invoke(key, object);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue