ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/ant/jmx/JMXAccessorInvokeTask.java

Path
ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/ant/jmx/JMXAccessorInvokeTask.java
Status
scanned
Type
file
Name
JMXAccessorInvokeTask.java
Extension
.java
Programming language
Java
Mime type
text/plain
File type
ASCII text, with CRLF line terminators
Tag

      
    
Rootfs path

      
    
Size
5770 (5.6 KB)
MD5
454473b0e01df7e831bba29aabea8eca
SHA1
486cd451848d0307cf8beba59f5873868140d4ac
SHA256
fa0a9fbfece19ca1681f740b9165ba84d87f4ab87efa4ca66318058ff33b9926
SHA512

      
    
SHA1_git
0f2d803df2652a78452cfdd7c7c10ee1a44a9408
Is binary

      
    
Is text
True
Is archive

      
    
Is media

      
    
Is legal

      
    
Is manifest

      
    
Is readme

      
    
Is top level

      
    
Is key file

      
    
JMXAccessorInvokeTask.java | 5.6 KB |

/* * 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.catalina.ant.jmx; import java.util.ArrayList; import java.util.List; import javax.management.MBeanServerConnection; import javax.management.ObjectName; import org.apache.tools.ant.BuildException; /** * Access <em>JMX</em> JSR 160 MBeans Server. * <ul> * <li>open more than one JSR 160 rmi connection</li> * <li>Get/Set Mbeans attributes</li> * <li>Call Mbean Operation with arguments</li> * <li>Argument values can be converted from string to int,long,float,double,boolean,ObjectName or InetAddress</li> * <li>Query Mbeans</li> * <li>Show Get, Call, Query result at Ant console log</li> * <li>Bind Get, Call, Query result at Ant properties</li> * </ul> * Examples: * <ul> * <li>Get a session attribute hello from session with ref <em>${sessionid.0}</em> form app * <em>Catalina:type=Manager,context=/ClusterTest,host=localhost</em> * * <pre> * &lt;jmx:invoke * name="Catalina:type=Manager,context=/ClusterTest,host=localhost" * operation="getSessionAttribute" * resultproperty="hello"&gt; * &lt;arg value="${sessionid.0}"/&gt; * &lt;arg value="Hello"/&gt; * &lt;/jmx:invoke&gt; * </pre> * * </li> * <li>Create new AccessLogger at localhost * * <pre> * &lt;jmx:invoke * name="Catalina:type=MBeanFactory" * operation="createAccessLoggerValve" * resultproperty="accessLoggerObjectName"&gt; * &lt;arg value="Catalina:type=Host,host=localhost"/&gt; * &lt;/jmx:invoke&gt; * </pre> * * </li> * <li>Remove existing AccessLogger at localhost * * <pre> * &lt;jmx:invoke * name="Catalina:type=MBeanFactory" * operation="removeValve"&gt; * &lt;arg value="Catalina:type=Valve,name=AccessLogValve,host=localhost"/&gt; * &lt;/jmx:invoke&gt; * </pre> * * </li> * </ul> * <p> * First call to a remote MBeanserver save the JMXConnection a referenz <em>jmx.server</em> * </p> * These tasks require Ant 1.6 or later interface. * * @since 5.5.10 */ public class JMXAccessorInvokeTask extends JMXAccessorTask { // ----------------------------------------------------- Instance Variables private String operation; private List<Arg> args = new ArrayList<>(); // ------------------------------------------------------------- Properties /** * @return Returns the operation. */ public String getOperation() { return operation; } /** * @param operation The operation to set. */ public void setOperation(String operation) { this.operation = operation; } public void addArg(Arg arg) { args.add(arg); } /** * @return Returns the args. */ public List<Arg> getArgs() { return args; } /** * @param args The args to set. */ public void setArgs(List<Arg> args) { this.args = args; } // ------------------------------------------------------ protected Methods @Override public String jmxExecute(MBeanServerConnection jmxServerConnection) throws Exception { if (getName() == null) { throw new BuildException("Must specify a 'name'"); } if ((operation == null)) { throw new BuildException("Must specify a 'operation' for call"); } return jmxInvoke(jmxServerConnection, getName()); } /** * Invoke specified operation. * * @param jmxServerConnection Connection to the JMX server * @param name The MBean name * * @return null (no error message to report other than exception) * * @throws Exception An error occurred */ protected String jmxInvoke(MBeanServerConnection jmxServerConnection, String name) throws Exception { Object result; if (args == null) { result = jmxServerConnection.invoke(new ObjectName(name), operation, null, null); } else { Object[] argsA = new Object[args.size()]; String[] sigA = new String[args.size()]; for (int i = 0; i < args.size(); i++) { Arg arg = args.get(i); if (arg.getType() == null) { arg.setType("java.lang.String"); sigA[i] = arg.getType(); argsA[i] = arg.getValue(); } else { sigA[i] = arg.getType(); argsA[i] = convertStringToType(arg.getValue(), arg.getType()); } } result = jmxServerConnection.invoke(new ObjectName(name), operation, argsA, sigA); } if (result != null) { echoResult(operation, result); createProperty(result); } return null; } }
Detected license expression
apache-2.0
Detected license expression (SPDX)
Apache-2.0
Percentage of license text
21.52
Copyrights

      
    
Holders

      
    
Authors

      
    
License detections License expression License expression SPDX
apache_2_0-4bde3f57-78aa-4201-96bf-531cba09e7de apache-2.0 Apache-2.0
URL Start line End line
http://www.apache.org/licenses/LICENSE-2.0 9 9