Skip to content

Commit

Permalink
[WFCORE-6788] Display in cli when server is in read-only mode
Browse files Browse the repository at this point in the history
  • Loading branch information
ChristinaDsl committed Aug 22, 2024
1 parent 8563703 commit a8e6f1e
Show file tree
Hide file tree
Showing 5 changed files with 34 additions and 3 deletions.
22 changes: 22 additions & 0 deletions cli/src/main/java/org/jboss/as/cli/Util.java
Original file line number Diff line number Diff line change
Expand Up @@ -1864,4 +1864,26 @@ public static String compactToString(ModelNode node) {
return stringWriter.toString();
}

public static boolean isServerInReadOnlyMode(CommandContext ctx) {
final ModelControllerClient client = ctx.getModelControllerClient();
final ModelNode operation = new ModelNode();
ModelNode result;
ModelNode address = operation.get("address");

address.add("core-service", "server-environment");
operation.get(Util.OPERATION).set(Util.READ_RESOURCE);
operation.get(Util.INCLUDE_RUNTIME).set(true);

try {
result = client.execute(operation);
if (isSuccess(result)) {
ModelNode serverEnv = result.get("result");
return serverEnv.get("read-only").asBoolean();
}
} catch (Exception e) {
}
return false;

}

}
Original file line number Diff line number Diff line change
Expand Up @@ -98,8 +98,8 @@ public void shutdown() {
private final AtomicInteger state = new AtomicInteger(CLOSED);

CLIModelControllerClient(final ControllerAddress address, CallbackHandler handler, int connectionTimeout,
final ConnectionCloseHandler closeHandler, Map<String, String> saslOptions, SecurityFactory<SSLContext> sslContextFactory,
boolean fallbackSslContext, ProtocolTimeoutHandler timeoutHandler, String clientBindAddress) throws IOException {
final ConnectionCloseHandler closeHandler, Map<String, String> saslOptions, SecurityFactory<SSLContext> sslContextFactory,
boolean fallbackSslContext, ProtocolTimeoutHandler timeoutHandler, String clientBindAddress) throws IOException {
this.handler = handler;
this.closeHandler = closeHandler;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1598,6 +1598,10 @@ String getPrompt() {
} else {
buffer.append("standalone@");
}
if (Util.isServerInReadOnlyMode(this)){
buffer.append("(read-only)");
printLine("Server is in read-only mode", "warning");
}
if (controllerHost != null) {
buffer.append(controllerHost).append(':').append(getControllerPort()).append(' ');
} else {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,10 +60,11 @@ public class ServerEnvironmentResourceDescription extends SimpleResourceDefiniti
static final AttributeDefinition PERMISSIBLE_STABILITY_LEVELS = new SimpleListAttributeDefinition.Builder("permissible-stability-levels", STABILITY)
.setFlags(AttributeAccess.Flag.STORAGE_RUNTIME)
.build();
public static final AttributeDefinition READ_ONLY = SimpleAttributeDefinitionBuilder.create("read-only", ModelType.BOOLEAN).setFlags(AttributeAccess.Flag.STORAGE_RUNTIME).build();

private static final AttributeDefinition[] SERVER_ENV_ATTRIBUTES = { BASE_DIR, CONFIG_DIR, CONFIG_FILE, CONTENT_DIR, DATA_DIR,
DEPLOY_DIR, EXT_DIRS, HOME_DIR, HOST_NAME, INITIAL_RUNNING_MODE, LAUNCH_TYPE, LOG_DIR, NODE_NAME,
QUALIFIED_HOST_NAME, SERVER_NAME, TEMP_DIR, START_SUSPENDED, GRACEFUL_STARTUP, STABILITY, PERMISSIBLE_STABILITY_LEVELS };
QUALIFIED_HOST_NAME, SERVER_NAME, TEMP_DIR, START_SUSPENDED, GRACEFUL_STARTUP, READ_ONLY, STABILITY, PERMISSIBLE_STABILITY_LEVELS };

private final ServerEnvironmentReadHandler osh;

Expand Down Expand Up @@ -176,6 +177,9 @@ public void execute(final OperationContext context, final ModelNode operation) t
if (equals(name, START_SUSPENDED)) {
result.set(environment.isStartSuspended());
}
if (equals(name, READ_ONLY)) {
result.set(environment.getServerConfigurationFile().getInteractionPolicy().isReadOnly());
}
if (equals(name, GRACEFUL_STARTUP)) {
result.set(environment.isStartGracefully());
} else if (equals(name, STABILITY)) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ server.env.server-name=The name of the server.
server.env.temp-dir=The temporary directory.
server.suspend-state=The suspend state of the server
server.env.start-suspended=Start the server suspended.
server.env.read-only=Start the server in read-only mode.
server.env.start-gracefully=Start the server gracefully.
server.env.stability=The stability level of the server.
server.env.permissible-stability-levels=A list of all the stability levels supported by this server.
Expand Down

0 comments on commit a8e6f1e

Please sign in to comment.