/*
** Copyright [2012] [Megam Systems]
**
** Licensed 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 org.megam.deccanplato.provider.twilio.handler;
import static org.megam.deccanplato.provider.Constants.*;
import static org.megam.deccanplato.provider.twilio.Constants.*;
import java.io.IOException;
import java.net.URISyntaxException;
import java.util.HashMap;
import java.util.Map;
import org.apache.http.client.ClientProtocolException;
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;
/**
* @author pandiyaraja
*
*This class deals with recording business activity of twilio.
*this class inplements list recordings, Transcriptions, view Recordings and delete recordings.
*/
public class RecordingsImpl implements BusinessActivity{
private Map<String, String> args;
private BusinessActivityInfo bizInfo;
/* (non-Javadoc)
* @see org.megam.deccanplato.provider.BusinessActivity#setArguments(org.megam.deccanplato.provider.core.BusinessActivityInfo, java.util.Map)
*/
@Override
public void setArguments(BusinessActivityInfo tempBizInfo,
Map<String, String> tempArgs) {
this.args = tempArgs;
this.bizInfo = tempBizInfo;
}
/* (non-Javadoc)
* @see org.megam.deccanplato.provider.BusinessActivity#run()
*/
@Override
public Map<String, String> run() {
Map<String, String> outMap = new HashMap<String, String>();
switch (bizInfo.getActivityFunction()) {
case LIST:
outMap=list(outMap);
break;
case TRANSCRIPTIONS:
outMap=transcriptions(outMap);
break;
case VIEW:
outMap=view(outMap);
break;
case DELETE:
outMap=delete(outMap);
break;
}
return outMap;
}
/**
* This method deletes a record by using RECORD SID.
* @param outMap
* @return
*/
private Map<String, String> delete(Map<String, String> outMap) {
final String account_view_url = TWILIO_URL + "Accounts/"
+ args.get(ACCOUNT_SID) + "/Recordings/"+args.get(RECORDING_SID)+".json";
Map<String, String> header = new HashMap<>();
header.put(PROVIDER, args.get(PROVIDER));
header.put(ACCOUNT_SID, args.get(ACCOUNT_SID));
header.put(OAUTH_TOKEN, args.get(OAUTH_TOKEN));
TransportTools tst = new TransportTools(account_view_url, null, header);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.delete(tst);
responseBody = response.entityToString();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method returns a particular recording by using
* recording sid.
* @param outMap
* @return
*/
private Map<String, String> view(Map<String, String> outMap) {
final String account_view_url = TWILIO_URL + "Accounts/"
+ args.get(ACCOUNT_SID) + "/Recordings/"+args.get(RECORDING_SID)+".json";
Map<String, String> header = new HashMap<>();
header.put(PROVIDER, args.get(PROVIDER));
header.put(ACCOUNT_SID, args.get(ACCOUNT_SID));
header.put(OAUTH_TOKEN, args.get(OAUTH_TOKEN));
TransportTools tst = new TransportTools(account_view_url, null, header);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.get(tst);
responseBody = response.entityToString();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* Transcription method use to return transcription recordings.
* by using recording sid.
* @param outMap
* @return
*/
private Map<String, String> transcriptions(Map<String, String> outMap) {
final String account_view_url = TWILIO_URL + "Accounts/"
+ args.get(ACCOUNT_SID) + "/Recordings/"+args.get(RECORDING_SID)+"/Transcriptions.json";
Map<String, String> header = new HashMap<>();
header.put(PROVIDER, args.get(PROVIDER));
header.put(ACCOUNT_SID, args.get(ACCOUNT_SID));
header.put(OAUTH_TOKEN, args.get(OAUTH_TOKEN));
TransportTools tst = new TransportTools(account_view_url, null, header);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.get(tst);
responseBody = response.entityToString();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outMap.put(OUTPUT, responseBody);
return outMap;
}
/**
* this method lists all recording of a accounts in twilio account and its details.
* @param outMap
* @return
*/
private Map<String, String> list(Map<String, String> outMap) {
final String account_view_url = TWILIO_URL + "Accounts/"
+ args.get(ACCOUNT_SID) + "/Recordings.json";
Map<String, String> header = new HashMap<>();
header.put(PROVIDER, args.get(PROVIDER));
header.put(ACCOUNT_SID, args.get(ACCOUNT_SID));
header.put(OAUTH_TOKEN, args.get(OAUTH_TOKEN));
TransportTools tst = new TransportTools(account_view_url, null, header);
String responseBody = null;
TransportResponse response = null;
try {
response = TransportMachinery.get(tst);
responseBody = response.entityToString();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
outMap.put(OUTPUT, responseBody);
return outMap;
}
/* (non-Javadoc)
* @see org.megam.deccanplato.provider.BusinessActivity#name()
*/
@Override
public String name() {
// TODO Auto-generated method stub
return "recording";
}
}