Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fail build on missing Javadocs #45

Merged
merged 17 commits into from
Jul 14, 2022
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 32 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,8 @@ apply from: 'gradle/formatting.gradle'

mainClassName = 'org.opensearch.sdk.ExtensionsRunner'

group 'org.example'
version '1.0-SNAPSHOT'
group 'org.opensearch.sdk'
version '1.0.0-SNAPSHOT'

repositories {
mavenLocal()
Expand All @@ -38,6 +38,10 @@ repositories {
mavenCentral()
}

configurations {
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
requireJavadoc
}

dependencies {
implementation "org.opensearch:opensearch:3.0.0-SNAPSHOT"
implementation group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.17.1'
Expand All @@ -62,8 +66,34 @@ dependencies {
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.8.2'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.8.2'
testImplementation "org.opensearch.test:framework:3.0.0-SNAPSHOT"
requireJavadoc "org.plumelib:require-javadoc:1.0.3"
}

// this task tests for the presence of javadocs but not the content/tags
task requireJavadoc(type: JavaExec) {
group = 'Documentation'
description = 'Ensures that Javadoc documentation exists.'
mainClass = "org.plumelib.javadoc.RequireJavadoc"
classpath = configurations.requireJavadoc
args "src/main/java"
args "--dont-require-private=true"
// temporary to get tests to pass, will complete netty javadocs later
args "--exclude=netty4"
// temporary until require-javadoc:1.0.4 allows suppressing getters and setters
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
args "--dont-require=[sg]et[Hostaddress|Hostport|Extensionname]"
}
check.dependsOn requireJavadoc

// this task checks for the content/tags of javadocs
task javadocStrict(type: Javadoc) {
group = 'Documentation'
description = 'Run Javadoc in strict mode: with -Xdoclint:all, on all members.'
source = sourceSets.main.allJava
classpath = sourceSets.main.runtimeClasspath
options.addStringOption('Xdoclint:all', '-quiet')
options.memberLevel = JavadocMemberLevel.PRIVATE
}
check.dependsOn javadocStrict
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved

test {
useJUnitPlatform()
Expand Down
37 changes: 37 additions & 0 deletions gradle.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
#
# SPDX-License-Identifier: Apache-2.0
#
# The OpenSearch Contributors require contributions made to
# this file be licensed under the Apache-2.0 license or a
# compatible open source license.
#
# Modifications Copyright OpenSearch Contributors. See
# GitHub history for details.
#

# Enable build caching
org.gradle.caching=true
org.gradle.warning.mode=none
org.gradle.parallel=true
# Workaround for https://github.com/diffplug/spotless/issues/834
org.gradle.jvmargs=-Xmx3g -XX:+HeapDumpOnOutOfMemoryError -Xss2m \
--add-exports jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED \
--add-exports jdk.compiler/com.sun.tools.javac.file=ALL-UNNAMED \
--add-exports jdk.compiler/com.sun.tools.javac.parser=ALL-UNNAMED \
--add-exports jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED \
--add-exports jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED
options.forkOptions.memoryMaximumSize=2g

# Disable duplicate project id detection
# See https://docs.gradle.org/current/userguide/upgrading_version_6.html#duplicate_project_names_may_cause_publication_to_fail
systemProp.org.gradle.dependency.duplicate.project.detection=false

# Enforce the build to fail on deprecated gradle api usage
systemProp.org.gradle.warning.mode=fail

# forcing to use TLS1.2 to avoid failure in vault
# see https://github.com/hashicorp/vault/issues/8750#issuecomment-631236121
systemProp.jdk.tls.client.protocols=TLSv1.2

# jvm args for faster test execution by default
systemProp.tests.jvm.argline=-XX:TieredStopAtLevel=1 -XX:ReservedCodeCacheSize=64m
17 changes: 17 additions & 0 deletions src/main/java/org/opensearch/sdk/ActionListener.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,30 @@
import java.net.Socket;
import java.net.UnknownHostException;

/**
* A listener for actions on the local port.
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
*/
public class ActionListener {

/**
* Get the local ephemeral port.
*
* @return The socket address for localhost.
* @throws UnknownHostException if the local host name could not be resolved into an address.
*/
@SuppressForbidden(reason = "need local ephemeral port")
protected static InetSocketAddress getLocalEphemeral() throws UnknownHostException {
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
return new InetSocketAddress(InetAddress.getLocalHost(), 0);
}

/**
* Run the action listener.
* This is presently a placeholder; when it receives a byte on the listening port, it terminates.
* Eventually some sort of operation will be added here.
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
*
* @param flag If true, waits for the other side to send a message.
* @param timeout How long to wait, in milliseconds. If zero, infinite timeout.
*/
public void runActionListener(boolean flag, int timeout) {
try (ServerSocket socket = new ServerSocket()) {

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,13 @@
import org.opensearch.threadpool.ThreadPool;
import org.opensearch.transport.TransportException;
import org.opensearch.transport.TransportResponseHandler;
import org.opensearch.transport.TransportService;

import java.io.IOException;

/**
* This class handles the response from OpenSearch to a {@link ExtensionsRunner#sendClusterSettingsRequest(TransportService)} call.
*/
public class ClusterSettingsResponseHandler implements TransportResponseHandler<ClusterSettingsResponse> {
private static final Logger logger = LogManager.getLogger(ClusterSettingsResponseHandler.class);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,13 @@
import org.opensearch.threadpool.ThreadPool;
import org.opensearch.transport.TransportException;
import org.opensearch.transport.TransportResponseHandler;
import org.opensearch.transport.TransportService;

import java.io.IOException;

/**
* This class handles the response from OpenSearch to a {@link ExtensionsRunner#sendClusterStateRequest(TransportService)} call.
*/
public class ClusterStateResponseHandler implements TransportResponseHandler<ClusterStateResponse> {
private static final Logger logger = LogManager.getLogger(ClusterStateResponseHandler.class);

Expand Down
8 changes: 7 additions & 1 deletion src/main/java/org/opensearch/sdk/ExtensionSettings.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,18 @@

package org.opensearch.sdk;

/**
* This class encapsulates the settings for an Extension.
*/
public class ExtensionSettings {

private String extensionname;
private String hostaddress;
private String hostport;
// Change the location to extension.yml file of the extension

/**
* Placeholder field. Change the location to extension.yml file of the extension.
*/
public static final String EXTENSION_DESCRIPTOR = "src/test/resources/extension.yml";

public String getExtensionname() {
Expand Down
104 changes: 88 additions & 16 deletions src/main/java/org/opensearch/sdk/ExtensionsRunner.java
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.dataformat.yaml.YAMLFactory;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.opensearch.Version;
Expand All @@ -33,16 +34,15 @@
import org.opensearch.indices.IndicesModule;
import org.opensearch.indices.breaker.CircuitBreakerService;
import org.opensearch.indices.breaker.NoneCircuitBreakerService;
import org.opensearch.sdk.netty4.Netty4Transport;
import org.opensearch.sdk.netty4.SharedGroupFactory;
import org.opensearch.search.SearchModule;
import org.opensearch.threadpool.ThreadPool;
import org.opensearch.transport.ClusterConnectionManager;
import org.opensearch.transport.ConnectionManager;
import org.opensearch.transport.TransportInterceptor;
import org.opensearch.transport.TransportService;
import org.opensearch.transport.TransportSettings;
import org.opensearch.transport.TransportInterceptor;

import org.opensearch.sdk.netty4.Netty4Transport;
import org.opensearch.sdk.netty4.SharedGroupFactory;

import java.io.File;
import java.io.IOException;
Expand All @@ -55,10 +55,20 @@
import static java.util.Collections.emptySet;
import static org.opensearch.common.UUIDs.randomBase64UUID;

/**
* The primary class to run an extension.
* <p>
* This class Javadoc will eventually be expanded with a full description/tutorial for users.
*/
public class ExtensionsRunner {
private ExtensionSettings extensionSettings = readExtensionSettings();
private DiscoveryNode opensearchNode;

/**
* Instantiates a new Extensions Runner.
*
* @throws IOException if the runner failed to connect to the OpenSearch cluster.
*/
public ExtensionsRunner() throws IOException {}

private final Settings settings = Settings.builder()
Expand All @@ -85,6 +95,12 @@ private DiscoveryNode getOpensearchNode() {
return opensearchNode;
}

/**
* Handles a plugin request from OpenSearch. This is the first request for the transport communication and will initialize the extension and will be a part of OpenSearch bootstrap.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the first request

It would by very valuable to have the full lifecycle of this process documented, maybe here? Then additional parts of the process would link back to this comment with a @see annotation

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just to give some context here. During bootstrap OpenSearch will look for any extensions available running on a different port. Once discovered, read their extensions.yml file and get the metadata of that extension.

*
* @param pluginRequest The request to handle.
peternied marked this conversation as resolved.
Show resolved Hide resolved
* @return A response to OpenSearch validating that this is an extension.
*/
PluginResponse handlePluginsRequest(PluginRequest pluginRequest) {
logger.info("Registering Plugin Request received from OpenSearch");
PluginResponse pluginResponse = new PluginResponse("RealExtension");
Expand All @@ -93,6 +109,13 @@ PluginResponse handlePluginsRequest(PluginRequest pluginRequest) {
return pluginResponse;
}

/**
* Handles a request for extension point indices from OpenSearch. The {@link #handlePluginsRequest(PluginRequest)} method must have been called first to initialize the extension.
peternied marked this conversation as resolved.
Show resolved Hide resolved
*
* @param indicesModuleRequest The request to handle.
* @param transportService The transport service communicating with OpenSearch.
* @return A response to OpenSearch with this extension's index and search listeners.
*/
IndicesModuleResponse handleIndicesModuleRequest(IndicesModuleRequest indicesModuleRequest, TransportService transportService) {
logger.info("Registering Indices Module Request received from OpenSearch");
IndicesModuleResponse indicesModuleResponse = new IndicesModuleResponse(true, true, true);
Expand All @@ -103,16 +126,28 @@ IndicesModuleResponse handleIndicesModuleRequest(IndicesModuleRequest indicesMod
return indicesModuleResponse;
}

// Works as beforeIndexRemoved
/**
* Handles a request for extension name from OpenSearch. The {@link #handlePluginsRequest(PluginRequest)} method must have been called first to initialize the extension.
*
* @param indicesModuleRequest The request to handle.
* @return A response acknowledging the request.
*/
IndicesModuleNameResponse handleIndicesModuleNameRequest(IndicesModuleRequest indicesModuleRequest) {
// Works as beforeIndexRemoved
logger.info("Registering Indices Module Name Request received from OpenSearch");
IndicesModuleNameResponse indicesModuleNameResponse = new IndicesModuleNameResponse(true);
return indicesModuleNameResponse;
}

// method : build netty transport
/**
* Initializes a Netty4Transport object. This object will be wrapped in a {@link TransportService} object.
*
* @param settings The transport settings to configure.
* @param threadPool A thread pool to use.
* @return The configured Netty4Transport object.
*/
public Netty4Transport getNetty4Transport(Settings settings, ThreadPool threadPool) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For later: Can change this method to createNetty4Transport.


// method : build netty transport
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
NetworkService networkService = new NetworkService(Collections.emptyList());
PageCacheRecycler pageCacheRecycler = new PageCacheRecycler(settings);
IndicesModule indicesModule = new IndicesModule(Collections.emptyList());
Expand Down Expand Up @@ -144,7 +179,13 @@ public Netty4Transport getNetty4Transport(Settings settings, ThreadPool threadPo
return transport;
}

public TransportService createTransportService(Settings settings) throws IOException {
/**
* Creates a TransportService object. This object will control communication between the extension and OpenSearch.
*
* @param settings The transport settings to configure.
* @return The configured TransportService object.
*/
public TransportService createTransportService(Settings settings) {

ThreadPool threadPool = new ThreadPool(settings);

Expand All @@ -169,8 +210,13 @@ public TransportService createTransportService(Settings settings) throws IOExcep
);
}

// manager method for transport service
/**
* Starts a TransportService.
*
* @param transportService The TransportService to start.
*/
public void startTransportService(TransportService transportService) {
// manager method for transport service
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved

// start transport service and accept incoming requests
transportService.start();
Expand Down Expand Up @@ -207,8 +253,13 @@ public void startTransportService(TransportService transportService) {

}

// Extension can use this API to get ClusterState from OpenSearch
/**
* Requests the cluster state from OpenSearch. The result will be handled by a {@link ClusterStateResponseHandler}.
*
* @param transportService The TransportService defining the connection to OpenSearch.
*/
public void sendClusterStateRequest(TransportService transportService) {
// Extension can use this API to get ClusterState from OpenSearch
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
logger.info("Sending Cluster State request to OpenSearch");
ClusterStateResponseHandler clusterStateResponseHandler = new ClusterStateResponseHandler();
try {
Expand All @@ -223,24 +274,34 @@ public void sendClusterStateRequest(TransportService transportService) {
}
}

// Extension can use this API to get ClusterSettings from OpenSearch
public void sendClusterSettingRequest(TransportService transportService) {
/**
* Requests the cluster settings from OpenSearch. The result will be handled by a {@link ClusterSettingsResponseHandler}.
*
* @param transportService The TransportService defining the connection to OpenSearch.
*/
public void sendClusterSettingsRequest(TransportService transportService) {
// Extension can use this API to get ClusterSettings from OpenSearch
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
logger.info("Sending Cluster Settings request to OpenSearch");
ClusterSettingsResponseHandler clusterSettingResponseHandler = new ClusterSettingsResponseHandler();
ClusterSettingsResponseHandler clusterSettingsResponseHandler = new ClusterSettingsResponseHandler();
try {
transportService.sendRequest(
opensearchNode,
ExtensionsOrchestrator.REQUEST_EXTENSION_CLUSTER_SETTINGS,
new ExtensionRequest(ExtensionsOrchestrator.RequestType.REQUEST_EXTENSION_CLUSTER_SETTINGS),
clusterSettingResponseHandler
clusterSettingsResponseHandler
);
} catch (Exception e) {
logger.info("Failed to send Cluster Settings request to OpenSearch", e);
}
}

// Extension can use this API to get LocalNode from OpenSearch
/**
* Requests the local node from OpenSearch. The result will be handled by a {@link LocalNodeResponseHandler}.
*
* @param transportService The TransportService defining the connection to OpenSearch.
*/
public void sendLocalNodeRequest(TransportService transportService) {
// Extension can use this API to get LocalNode from OpenSearch
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
logger.info("Sending Local Node request to OpenSearch");
LocalNodeResponseHandler localNodeResponseHandler = new LocalNodeResponseHandler();
try {
Expand All @@ -259,12 +320,23 @@ private Settings getSettings() {
return settings;
}

// manager method for action listener
/**
* Starts an ActionListener.
*
* @param timeout The timeout for the listener in milliseconds. A timeout of 0 means no timeout.
*/
public void startActionListener(int timeout) {
// manager method for action listener
dbwiddis marked this conversation as resolved.
Show resolved Hide resolved
final ActionListener actionListener = new ActionListener();
actionListener.runActionListener(true, timeout);
}

/**
* Run the Extension. Imports settings, establishes a connection with an OpenSearch cluster via a Transport Service, and sets up a listener for responses.
*
* @param args Unused
* @throws IOException if the runner failed to connect to the OpenSearch cluster.
*/
public static void main(String[] args) throws IOException {

ExtensionsRunner extensionsRunner = new ExtensionsRunner();
Expand Down
Loading