/** * Copyright (c) 2009--2013 Red Hat, Inc. * * This software is licensed to you under the GNU General Public License, * version 2 (GPLv2). There is NO WARRANTY for this software, express or * implied, including the implied warranties of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2 * along with this software; if not, see * http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt. * * Red Hat trademarks are not licensed under GPLv2. No permission is * granted to use or replicate Red Hat trademarks that are incorporated * in this software or its documentation. */ package com.redhat.rhn.frontend.xmlrpc.serializer; import java.io.IOException; import java.io.Writer; import redstone.xmlrpc.XmlRpcException; import redstone.xmlrpc.XmlRpcSerializer; import com.redhat.rhn.frontend.dto.ChannelTreeNode; import com.redhat.rhn.frontend.xmlrpc.serializer.util.SerializerHelper; /** * ChannelTreeNodeSerializer: Converts a ChannelTreeNode object for * representation as an XMLRPC struct. * @version $Rev$ * * @xmlrpc.doc * #struct("channel info") * #prop("int", "id") * #prop("string", "label") * #prop("string", "name") * #prop("string", "provider_name") * #prop("int", "packages") * #prop("int", "systems") * #prop("string", "arch_name") * #struct_end() */ public class ChannelTreeNodeSerializer extends RhnXmlRpcCustomSerializer { /** * {@inheritDoc} */ public Class getSupportedClass() { return ChannelTreeNode.class; } /** * {@inheritDoc} */ protected void doSerialize(Object value, Writer output, XmlRpcSerializer serializer) throws XmlRpcException, IOException { ChannelTreeNode ctn = (ChannelTreeNode)value; SerializerHelper helper = new SerializerHelper(serializer); helper.add("id", ctn.getId()); helper.add("label", ctn.getChannelLabel()); helper.add("name", ctn.getName()); if (ctn.getOrgId() != null) { helper.add("provider_name", ctn.getOrgName()); } else { helper.add("provider_name", "Red Hat, Inc."); } helper.add("packages", ctn.getPackageCount()); if (ctn.getSystemCount() == null) { // it is possible for the current query to result in the count // being null; however, in this scenario, we still want to serialize the // result as 0. helper.add("systems", new Integer(0)); } else { helper.add("systems", ctn.getSystemCount()); } helper.add("arch_name", ctn.getArchName()); helper.writeTo(output); } }