/**
* Copyright (C) 2010 Cloud.com, Inc. All rights reserved.
*
* This software is licensed under the GNU General Public License v3 or later.
*
* It is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
*/
package com.cloud.api.commands;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import org.apache.log4j.Logger;
import com.cloud.api.BaseCmd;
import com.cloud.api.ServerApiException;
import com.cloud.async.AsyncJobResult;
import com.cloud.async.executor.IngressRuleResultObject;
import com.cloud.async.executor.NetworkGroupResultObject;
import com.cloud.exception.PermissionDeniedException;
import com.cloud.serializer.SerializerHelper;
import com.cloud.utils.Pair;
public class QueryAsyncJobResultCmd extends BaseCmd {
public static final Logger s_logger = Logger.getLogger(QueryAsyncJobResultCmd.class.getName());
private static final String s_name = "queryasyncjobresultresponse";
private static final List> s_properties = new ArrayList>();
static {
s_properties.add(new Pair(BaseCmd.Properties.JOB_ID, Boolean.TRUE));
}
public String getName() {
return s_name;
}
public List> getProperties() {
return s_properties;
}
@Override
public List> execute(Map params) {
Long jobId = (Long)params.get(BaseCmd.Properties.JOB_ID.getName());
AsyncJobResult result;
try {
result = getManagementServer().queryAsyncJobResult(jobId);
} catch (PermissionDeniedException e) {
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Permission denied");
}
List> returnValues = new ArrayList>();
returnValues.add(new Pair(BaseCmd.Properties.JOB_ID.getName(), jobId));
returnValues.add(new Pair(BaseCmd.Properties.JOB_STATUS.getName(), Integer.valueOf(result.getJobStatus())));
returnValues.add(new Pair(BaseCmd.Properties.JOB_PROCESS_STATUS.getName(), Integer.valueOf(result.getProcessStatus())));
returnValues.add(new Pair(BaseCmd.Properties.JOB_RESULT_CODE.getName(), Integer.valueOf(result.getResultCode())));
Object resultObject = result.getResultObject();
if(resultObject != null) {
Class> clz = resultObject.getClass();
if(clz.isPrimitive() || clz.getSuperclass() == Number.class || clz == String.class || clz == Date.class) {
returnValues.add(new Pair(BaseCmd.Properties.JOB_RESULT_TYPE.getName(), "text"));
SerializerHelper.appendPairList(returnValues, resultObject, BaseCmd.Properties.JOB_RESULT.getName());
} else {
returnValues.add(new Pair(BaseCmd.Properties.JOB_RESULT_TYPE.getName(), "object"));
if(result.getCmdOriginator() != null && !result.getCmdOriginator().isEmpty()) {
List> resultValues = new ArrayList>();
if (resultObject instanceof NetworkGroupResultObject) {
serializeNetworkGroupResults(resultValues, (NetworkGroupResultObject)resultObject);
} else {
SerializerHelper.appendPairList(resultValues, resultObject, BaseCmd.Properties.JOB_RESULT.getName());
}
returnValues.add(new Pair(result.getCmdOriginator(), new Object[] { resultValues } ));
}
}
}
return returnValues;
}
// For now network groups are the only objects with nested objects inside, so we special case serialization to handle this one case.
// In the future, if a generic serialization that handles nested objects is implemented then this special case can be removed.
private void serializeNetworkGroupResults(List> resultValues, NetworkGroupResultObject resultObject) {
if (resultObject != null) {
resultValues.add(new Pair(BaseCmd.Properties.ID.getName(), resultObject.getId().toString()));
resultValues.add(new Pair(BaseCmd.Properties.NAME.getName(), resultObject.getName()));
resultValues.add(new Pair(BaseCmd.Properties.DESCRIPTION.getName(), resultObject.getDescription()));
resultValues.add(new Pair(BaseCmd.Properties.ACCOUNT.getName(), resultObject.getAccountName()));
resultValues.add(new Pair(BaseCmd.Properties.DOMAIN_ID.getName(), resultObject.getDomainId().toString()));
List ingressRules = resultObject.getIngressRules();
if ((ingressRules != null) && !ingressRules.isEmpty()) {
Object[] ingressDataArray = new Object[ingressRules.size()];
int j = 0;
for (IngressRuleResultObject ingressRule : ingressRules) {
List> ingressData = new ArrayList>();
ingressData.add(new Pair(BaseCmd.Properties.RULE_ID.getName(), ingressRule.getId().toString()));
ingressData.add(new Pair(BaseCmd.Properties.PROTOCOL.getName(), ingressRule.getProtocol()));
if ("icmp".equalsIgnoreCase(ingressRule.getProtocol())) {
ingressData.add(new Pair(BaseCmd.Properties.ICMP_TYPE.getName(), Integer.valueOf(ingressRule.getStartPort()).toString()));
ingressData.add(new Pair(BaseCmd.Properties.ICMP_CODE.getName(), Integer.valueOf(ingressRule.getEndPort()).toString()));
} else {
ingressData.add(new Pair(BaseCmd.Properties.START_PORT.getName(), Integer.valueOf(ingressRule.getStartPort()).toString()));
ingressData.add(new Pair(BaseCmd.Properties.END_PORT.getName(), Integer.valueOf(ingressRule.getEndPort()).toString()));
}
if (ingressRule.getAllowedNetworkGroup() != null) {
ingressData.add(new Pair(BaseCmd.Properties.NETWORK_GROUP_NAME.getName(), ingressRule.getAllowedNetworkGroup()));
ingressData.add(new Pair(BaseCmd.Properties.ACCOUNT.getName(), ingressRule.getAllowedNetGroupAcct()));
} else if (ingressRule.getAllowedSourceIpCidr() != null) {
ingressData.add(new Pair(BaseCmd.Properties.CIDR.getName(), ingressRule.getAllowedSourceIpCidr()));
}
ingressDataArray[j++] = ingressData;
}
resultValues.add(new Pair("ingressrule", ingressDataArray));
}
}
}
}