com.rabbitmq.tools.jsonrpc.ServiceDescription Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of amqp-client Show documentation
Show all versions of amqp-client Show documentation
The RabbitMQ Java client library allows Java applications to interface with RabbitMQ.
// Copyright (c) 2007-2023 Broadcom. All Rights Reserved. The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// This software, the RabbitMQ Java client library, is triple-licensed under the
// Mozilla Public License 2.0 ("MPL"), the GNU General Public License version 2
// ("GPL") and the Apache License version 2 ("ASL"). For the MPL, please see
// LICENSE-MPL-RabbitMQ. For the GPL, please see LICENSE-GPL2. For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].
package com.rabbitmq.tools.jsonrpc;
import java.lang.reflect.Method;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import com.rabbitmq.tools.json.JSONUtil;
/**
* Description of a JSON-RPC service.
*/
public class ServiceDescription {
public static final String JSON_RPC_VERSION = "1.1";
/** The service name */
private String name;
/** ID for the service */
private String id;
/** Version of the service */
private String version;
/** Human-readable summary for the service */
private String summary;
/** Human-readable instructions for how to get information on the service's operation */
private String help;
/** Map from procedure name to {@link ProcedureDescription} */
private Map procedures;
public ServiceDescription(Map rawServiceDescription) {
JSONUtil.tryFill(this, rawServiceDescription);
}
public ServiceDescription(Class> klass) {
this.procedures = new HashMap<>();
for (Method m: klass.getMethods()) {
ProcedureDescription proc = new ProcedureDescription(m);
addProcedure(proc);
}
}
public ServiceDescription() {
// No work to do here
}
/** Gets a collection of all {@link ProcedureDescription} for this service */
public Collection getProcs() {
return procedures.values();
}
/** Private API - used via reflection during parsing/loading */
public void setProcs(Collection