blob: a130d6728ec89e801d8c62c895312d2867e722f2 [file] [log] [blame]
// 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 com.cloud.test.utils;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.StringTokenizer;
import java.util.TreeMap;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpMethod;
import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.log4j.Logger;
public class SubmitCert {
public static String url = "Action=SetCertificate";
public static String secretKey;
public static String apiKey;
public static String host;
public static String port;
public static String command;
public static String accessPoint;
public static String signatureMethod;
public static String fileName = "tool.properties";
public static String certFileName;
public static String cert;
public static final Logger s_logger = Logger.getLogger(SubmitCert.class.getName());
public static void main(String[] args) {
// Parameters
List<String> argsList = Arrays.asList(args);
Iterator<String> iter = argsList.iterator();
while (iter.hasNext()) {
String arg = iter.next();
if (arg.equals("-c")) {
certFileName = iter.next();
}
if (arg.equals("-s")) {
secretKey = iter.next();
}
if (arg.equals("-a")) {
apiKey = iter.next();
}
if (arg.equals("-action")) {
url = "Action=" + iter.next();
}
}
Properties prop = new Properties();
try {
prop.load(new FileInputStream("conf/tool.properties"));
} catch (IOException ex) {
s_logger.error("Error reading from conf/tool.properties", ex);
System.exit(2);
}
host = prop.getProperty("host");
port = prop.getProperty("port");
if (url.equals("Action=SetCertificate") && certFileName == null) {
s_logger.error("Please set path to certificate (including file name) with -c option");
System.exit(1);
}
if (secretKey == null) {
s_logger.error("Please set secretkey with -s option");
System.exit(1);
}
if (apiKey == null) {
s_logger.error("Please set apikey with -a option");
System.exit(1);
}
if (host == null) {
s_logger.error("Please set host in tool.properties file");
System.exit(1);
}
if (port == null) {
s_logger.error("Please set port in tool.properties file");
System.exit(1);
}
TreeMap<String, String> param = new TreeMap<String, String>();
String req = "GET\n" + host + ":" + prop.getProperty("port") + "\n/" + prop.getProperty("accesspoint") + "\n";
String temp = "";
if (certFileName != null) {
cert = readCert(certFileName);
param.put("cert", cert);
}
param.put("AWSAccessKeyId", apiKey);
param.put("Expires", prop.getProperty("expires"));
param.put("SignatureMethod", prop.getProperty("signaturemethod"));
param.put("SignatureVersion", "2");
param.put("Version", prop.getProperty("version"));
StringTokenizer str1 = new StringTokenizer(url, "&");
while (str1.hasMoreTokens()) {
String newEl = str1.nextToken();
StringTokenizer str2 = new StringTokenizer(newEl, "=");
String name = str2.nextToken();
String value = str2.nextToken();
param.put(name, value);
}
//sort url hash map by key
Set c = param.entrySet();
Iterator it = c.iterator();
while (it.hasNext()) {
Map.Entry me = (Map.Entry)it.next();
String key = (String)me.getKey();
String value = (String)me.getValue();
try {
temp = temp + key + "=" + URLEncoder.encode(value, "UTF-8") + "&";
} catch (Exception ex) {
s_logger.error("Unable to set parameter " + value + " for the command " + param.get("command"), ex);
}
}
temp = temp.substring(0, temp.length() - 1);
String requestToSign = req + temp;
String signature = UtilsForTest.signRequest(requestToSign, secretKey);
String encodedSignature = "";
try {
encodedSignature = URLEncoder.encode(signature, "UTF-8");
} catch (Exception ex) {
ex.printStackTrace();
}
String url = "http://" + host + ":" + prop.getProperty("port") + "/" + prop.getProperty("accesspoint") + "?" + temp + "&Signature=" + encodedSignature;
s_logger.info("Sending request with url: " + url + "\n");
sendRequest(url);
}
public static String readCert(String filePath) {
try {
StringBuffer fileData = new StringBuffer(1000);
BufferedReader reader = new BufferedReader(new FileReader(filePath));
char[] buf = new char[1024];
int numRead = 0;
while ((numRead = reader.read(buf)) != -1) {
String readData = String.valueOf(buf, 0, numRead);
fileData.append(readData);
buf = new char[1024];
}
reader.close();
return fileData.toString();
} catch (Exception ex) {
s_logger.error(ex);
return null;
}
}
public static void sendRequest(String url) {
try {
HttpClient client = new HttpClient();
HttpMethod method = new GetMethod(url);
int responseCode = client.executeMethod(method);
String is = method.getResponseBodyAsString();
s_logger.info("Response code " + responseCode + ": " + is);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}