package org.xmlsh.aws; import java.io.IOException; import java.util.List; import javax.xml.stream.XMLStreamException; import net.sf.saxon.s9api.SaxonApiException; import org.xmlsh.aws.util.AWSEC2Command; import org.xmlsh.aws.util.SafeXMLStreamWriter; import org.xmlsh.core.CoreException; import org.xmlsh.core.Options; import org.xmlsh.core.OutputPort; import org.xmlsh.core.UnexpectedException; import org.xmlsh.core.XValue; import org.xmlsh.util.Util; import com.amazonaws.AmazonServiceException; import com.amazonaws.services.ec2.model.DescribeVolumesRequest; import com.amazonaws.services.ec2.model.DescribeVolumesResult; import com.amazonaws.services.ec2.model.Volume; public class ec2DescribeVolumes extends AWSEC2Command { /** * @param args * @throws IOException */ @Override public int run(List<XValue> args) throws Exception { Options opts = getOptions(); parseOptions(opts, args); args = opts.getRemainingArgs(); parseCommonOptions(opts); setSerializeOpts(this.getSerializeOpts(opts)); try { getEC2Client(opts); } catch (UnexpectedException e) { usage( e.getLocalizedMessage() ); return 1; } int ret; switch(args.size()){ case 0: ret = describe(null); break; default: ret = describe(args); break; } return ret; } private int describe(List<XValue> args) throws IOException, XMLStreamException, SaxonApiException, CoreException, InterruptedException { OutputPort stdout = getStdout(); mWriter = new SafeXMLStreamWriter(stdout.asXMLStreamWriter(getSerializeOpts())); startDocument(); startElement(getName()); DescribeVolumesRequest request = new DescribeVolumesRequest(); ; if( args != null ){ request.setVolumeIds(Util.toStringList(args)); } DescribeVolumesResult result =null ; int retry = rateRetry ; int delay = retryDelay ; do { try { result = mAmazon.describeVolumes(request); break ; } catch( AmazonServiceException e ){ mShell.printErr("AmazonServiceException" , e ); if( retry > 0 && Util.isEqual("RequestLimitExceeded",e.getErrorCode())){ mShell.printErr("AWS RequestLimitExceeded - sleeping " + delay ); Thread.sleep( delay ); retry--; delay *= 2 ; } else throw e; } } while( retry > 0 ); if( args != null ){ request.setVolumeIds(Util.toStringList(args)); } traceCall("describeVolumes"); for( Volume volume : result.getVolumes() ){ writeVolume(volume); endElement(); } endElement(); endDocument(); closeWriter(); stdout.writeSequenceTerminator(getSerializeOpts()); stdout.release(); return 0; } }