/**
* “Copyright 2012 Megam Systems”
* This program 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
* (at your option) 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 <http://www.gnu.org/licenses/>.
**/
package org.megam.deccanplato.provider.zoho.invoice.handler;
import static org.megam.deccanplato.provider.Constants.*;
import static org.megam.deccanplato.provider.zoho.invoice.Constants.*;
import java.io.IOException;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.xml.bind.JAXBException;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.message.BasicNameValuePair;
import org.megam.deccanplato.http.TransportMachinery;
import org.megam.deccanplato.http.TransportResponse;
import org.megam.deccanplato.http.TransportTools;
import org.megam.deccanplato.provider.BusinessActivity;
import org.megam.deccanplato.provider.core.BusinessActivityInfo;
import org.megam.deccanplato.provider.zoho.invoice.info.Contact;
import org.megam.deccanplato.provider.zoho.invoice.info.InvoiceUpdate;
import org.megam.deccanplato.provider.zoho.invoice.info.CustomFields;
import org.megam.deccanplato.provider.zoho.invoice.info.Customer;
import org.megam.deccanplato.provider.zoho.invoice.info.ExpenseCategory;
/**
* @author pandiyaraja
*
* this class implements ExpenseCategory business methods
* that are create, list, update and delete
*/
public class ExpenseCategoryImpl implements BusinessActivity {
private static final String ZOHO_INVOICE_EXPENSECATEGORY="https://invoice.zoho.com/api/expensecategories/";
private Map<String, String> args;
private BusinessActivityInfo bizInfo;
@Override
public void setArguments(BusinessActivityInfo tempBizInfo,
Map<String, String> tempArgs) {
this.args = tempArgs;
this.bizInfo = tempBizInfo;
}
@Override
public Map<String, String> run() {
Map<String, String> outMap = new HashMap<>();
switch (bizInfo.getActivityFunction()) {
case CREATE:
outMap = create(outMap);
break;
case LIST:
outMap = list(outMap);
break;
case UPDATE:
outMap = update(outMap);
break;
case DELETE:
outMap = delete(outMap);
break;
default:
break;
}
return outMap;
}
/**
* this method creates an Expensecategory in zoho invoice and returns that expensecategory details.
* and it uses the business support class expensecategory to populate ZOHO XML
* input This method takes input as a MAP(contains json dada) and returns a
* MAP.
*
* @param outMap
*/
private Map<String, String> create(Map<String, String> outMap) {
final String ZOHO_INVOICE_EXPENSECATEGORY_CREATE_URL = ZOHO_INVOICE_EXPENSECATEGORY+"create";
ExpenseCategory expcat = new ExpenseCategory();
expcat.setCategoryName(args.get(CATEGORY_NAME));
expcat.setDescription(args.get(DESCRIPTION));
String xmlout = null;
try {
xmlout = expcat.toXMLString();
} catch (JAXBException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
List<NameValuePair> createAttrList = new ArrayList<NameValuePair>();
createAttrList.add(new BasicNameValuePair(OAUTH_TOKEN, args
.get(AUTHTOKEN)));
createAttrList.add(new BasicNameValuePair(ZOHO_SCOPE, SCOPE));
createAttrList.add(new BasicNameValuePair(ZOHO_XMLSTRING, xmlout));
createAttrList.add(new BasicNameValuePair(APIKEY, args.get(APIKEY)));
TransportTools tst = new TransportTools(ZOHO_INVOICE_EXPENSECATEGORY_CREATE_URL,
createAttrList);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.post(tst);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
responseBody = response.entityToString();
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method lists all expensecategory in zoho invoice and returns a list
* expensecategory details. This method takes input as a MAP(contains json dada) and
* returns a MAP.
*
* @param outMap
*/
private Map<String, String> list(Map<String, String> outMap) {
List<NameValuePair> listAttrList = new ArrayList<NameValuePair>();
listAttrList.add(new BasicNameValuePair(OAUTH_TOKEN, args
.get(AUTHTOKEN)));
listAttrList.add(new BasicNameValuePair(ZOHO_SCOPE, SCOPE));
listAttrList.add(new BasicNameValuePair(APIKEY, args.get(APIKEY)));
TransportTools tst = new TransportTools(ZOHO_INVOICE_EXPENSECATEGORY,
listAttrList, null, true, "UTF-8");
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.get(tst);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
responseBody = response.entityToString();
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method update a particular expensecategory in zoho invoice
* and returns expensecategory details. This method takes input as a
* MAP(contains json dada) and returns a MAP.
*
* @param outMap
*/
private Map<String, String> update(Map<String, String> outMap) {
final String ZOHO_INVOICE_EXPENSECATEGORY_UPDATE_URL = ZOHO_INVOICE_EXPENSECATEGORY+"update";
ExpenseCategory expcat = new ExpenseCategory();
expcat.setCategoryID(args.get(ID));
expcat.setCategoryName(args.get(CATEGORY_NAME));
expcat.setDescription(args.get(DESCRIPTION));
String xmlout = null;
try {
xmlout = expcat.toXMLString();
} catch (JAXBException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
List<NameValuePair> updateAttrList = new ArrayList<NameValuePair>();
updateAttrList.add(new BasicNameValuePair(OAUTH_TOKEN, args
.get(AUTHTOKEN)));
updateAttrList.add(new BasicNameValuePair(ZOHO_SCOPE, SCOPE));
updateAttrList.add(new BasicNameValuePair(ZOHO_XMLSTRING, xmlout));
updateAttrList.add(new BasicNameValuePair(APIKEY, args.get(APIKEY)));
TransportTools tst = new TransportTools(ZOHO_INVOICE_EXPENSECATEGORY_UPDATE_URL,
updateAttrList);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.post(tst);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
responseBody = response.entityToString();
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method delete a particular expensecategory in zoho invoice and returns
* status code. This method takes input as a
* MAP(contains json dada) and returns a MAP.
*
* @param outMap
*/
private Map<String, String> delete(Map<String, String> outMap) {
final String ZOHO_INVOICE_EXPENSECATEGORY_DELETE_URL = ZOHO_INVOICE_EXPENSECATEGORY+"delete/"
+ args.get(ID);
List<NameValuePair> deleteAttrList = new ArrayList<NameValuePair>();
deleteAttrList.add(new BasicNameValuePair(OAUTH_TOKEN, args
.get(AUTHTOKEN)));
deleteAttrList.add(new BasicNameValuePair(ZOHO_SCOPE, SCOPE));
deleteAttrList.add(new BasicNameValuePair(APIKEY, args.get(APIKEY)));
TransportTools tst = new TransportTools(ZOHO_INVOICE_EXPENSECATEGORY_DELETE_URL,
deleteAttrList);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.post(tst);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
responseBody = response.entityToString();
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method returns business method name to perform action in that
* zoho invoice Module
*/
@Override
public String name() {
return "expensecategory";
}
}