/**
* 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.List;
import java.util.Map;
import org.apache.log4j.Logger;
import com.cloud.api.BaseCmd;
import com.cloud.api.ServerApiException;
import com.cloud.configuration.ConfigurationVO;
import com.cloud.server.Criteria;
import com.cloud.utils.Pair;
public class ListCfgsByCmd extends BaseCmd {
public static final Logger s_logger = Logger.getLogger(ListCfgsByCmd.class.getName());
private static final String s_name = "listconfigurationsresponse";
private static final List> s_properties = new ArrayList>();
static {
s_properties.add(new Pair(BaseCmd.Properties.NAME, Boolean.FALSE));
s_properties.add(new Pair(BaseCmd.Properties.CATEGORY, Boolean.FALSE));
s_properties.add(new Pair(BaseCmd.Properties.KEYWORD, Boolean.FALSE));
s_properties.add(new Pair(BaseCmd.Properties.PAGE, Boolean.FALSE));
s_properties.add(new Pair(BaseCmd.Properties.PAGESIZE, Boolean.FALSE));
}
public String getName() {
return s_name;
}
public List> getProperties() {
return s_properties;
}
@Override
public List> execute(Map params) {
String name = (String) params.get(BaseCmd.Properties.NAME.getName());
String category = (String) params.get(BaseCmd.Properties.CATEGORY.getName());
String keyword = (String)params.get(BaseCmd.Properties.KEYWORD.getName());
Integer page = (Integer)params.get(BaseCmd.Properties.PAGE.getName());
Integer pageSize = (Integer)params.get(BaseCmd.Properties.PAGESIZE.getName());
Long startIndex = Long.valueOf(0);
int pageSizeNum = 100;
if (pageSize != null) {
pageSizeNum = pageSize.intValue();
}
if (page != null) {
int pageNum = page.intValue();
if (pageNum > 0) {
startIndex = Long.valueOf(pageSizeNum * (pageNum-1));
}
}
Criteria c = new Criteria ("name", Boolean.TRUE, startIndex, Long.valueOf(pageSizeNum));
if (keyword != null) {
c.addCriteria(Criteria.KEYWORD, keyword);
} else {
c.addCriteria(Criteria.NAME, name);
c.addCriteria(Criteria.CATEGORY, category);
}
List configs = getManagementServer().searchForConfigurations(c, false);
if (configs == null) {
throw new ServerApiException(BaseCmd.INTERNAL_ERROR, "Unable to find configuration values for specified search criteria.");
}
List> cfgTags = new ArrayList>();
Object[] cfgDataTags = new Object[configs.size()];
int i = 0;
for (ConfigurationVO config : configs) {
List> cfgData = new ArrayList>();
cfgData.add(new Pair(BaseCmd.Properties.CATEGORY.getName(), config.getCategory()));
cfgData.add(new Pair(BaseCmd.Properties.NAME.getName(), config.getName()));
cfgData.add(new Pair(BaseCmd.Properties.VALUE.getName(), config.getValue()));
cfgData.add(new Pair(BaseCmd.Properties.DESCRIPTION.getName(), config.getDescription()));
cfgDataTags[i++] = cfgData;
}
Pair cfgTag = new Pair("configuration", cfgDataTags);
cfgTags.add(cfgTag);
return cfgTags;
}
}