Example usage for com.amazonaws.services.sqs.model GetQueueUrlResult getQueueUrl

List of usage examples for com.amazonaws.services.sqs.model GetQueueUrlResult getQueueUrl

Introduction

In this page you can find the example usage for com.amazonaws.services.sqs.model GetQueueUrlResult getQueueUrl.

Prototype


public String getQueueUrl() 

Source Link

Document

The URL of the queue.

Usage

From source file:it.polimi.modaclouds.cpimlibrary.taskqueuemng.AmazonTaskQueue.java

License:Apache License

@Override
public void add(CloudTask t) throws CloudTaskQueueException {
    GetQueueUrlRequest getQueueUrlRequest = new GetQueueUrlRequest(queueName);
    GetQueueUrlResult getQueueUrlResult = sqs.getQueueUrl(getQueueUrlRequest);
    String queueUrl = getQueueUrlResult.getQueueUrl();
    String id = sqs.sendMessage(new SendMessageRequest(queueUrl, buildMessage(t))).getMessageId();
    cloud_task_ids.put(t.getTaskName(), id);
}

From source file:org.apache.camel.component.aws.sqs.SqsEndpoint.java

License:Apache License

@Override
protected void doStart() throws Exception {
    client = getConfiguration().getAmazonSQSClient() != null ? getConfiguration().getAmazonSQSClient()
            : getClient();//from w  w  w  .j ava  2 s .  c o m

    // If both region and Account ID is provided the queue URL can be built manually.
    // This allows accessing queues where you don't have permission to list queues or query queues
    if (configuration.getRegion() != null && configuration.getQueueOwnerAWSAccountId() != null) {
        queueUrl = "https://sqs." + configuration.getRegion() + ".amazonaws.com/"
                + configuration.getQueueOwnerAWSAccountId() + "/" + configuration.getQueueName();
    } else if (configuration.getQueueOwnerAWSAccountId() != null) {
        GetQueueUrlRequest getQueueUrlRequest = new GetQueueUrlRequest();
        getQueueUrlRequest.setQueueName(configuration.getQueueName());
        getQueueUrlRequest.setQueueOwnerAWSAccountId(configuration.getQueueOwnerAWSAccountId());
        GetQueueUrlResult getQueueUrlResult = client.getQueueUrl(getQueueUrlRequest);
        queueUrl = getQueueUrlResult.getQueueUrl();
    } else {
        // check whether the queue already exists
        ListQueuesResult listQueuesResult = client.listQueues();
        for (String url : listQueuesResult.getQueueUrls()) {
            if (url.endsWith("/" + configuration.getQueueName())) {
                queueUrl = url;
                LOG.trace("Queue available at '{}'.", queueUrl);
                break;
            }
        }
    }

    if (queueUrl == null) {
        createQueue(client);
    } else {
        updateQueueAttributes(client);
    }
}

From source file:org.duracloud.common.sns.SnsSubscriptionManager.java

License:Apache License

public synchronized void connect() {
    if (initialized) {
        throw new DuraCloudRuntimeException("this manager is already connected");
    }/*from www  .jav  a2 s  . co  m*/

    //create sqs queue
    log.info("creating sqs queue");
    CreateQueueRequest request = new CreateQueueRequest(this.queueName);
    Map<String, String> attributes = new HashMap<String, String>();
    attributes.put("ReceiveMessageWaitTimeSeconds", "20");
    request.setAttributes(attributes);
    CreateQueueResult result;
    try {
        result = sqsClient.createQueue(request);
        this.queueUrl = result.getQueueUrl();
        log.info("sqs queue created: {}", this.queueUrl);
    } catch (QueueNameExistsException ex) {
        log.info("queue with name {} already exists.");
        GetQueueUrlResult queueUrlResult = sqsClient.getQueueUrl(this.queueName);
        this.queueUrl = queueUrlResult.getQueueUrl();
        log.info("sqs queue url retrieved: {}", this.queueUrl);
    }

    String queueArnKey = "QueueArn";
    GetQueueAttributesResult getQueueAttrResult = sqsClient.getQueueAttributes(this.queueUrl,
            Arrays.asList(queueArnKey));
    log.info("subscribing {} to {}", queueUrl, topicArn);

    String queueArn = getQueueAttrResult.getAttributes().get(queueArnKey);

    SubscribeResult subscribeResult = this.snsClient.subscribe(topicArn, "sqs", queueArn);
    this.subscriptionArn = subscribeResult.getSubscriptionArn();

    Map<String, String> queueAttributes = new HashMap<String, String>();
    queueAttributes.put("Policy", generateSqsPolicyForTopic(queueArn, topicArn));

    sqsClient.setQueueAttributes(new SetQueueAttributesRequest(queueUrl, queueAttributes));

    log.info("subscription complete: {}", this.subscriptionArn);

    //subscribe queue to topic
    this.initialized = true;

    startPolling();

}

From source file:org.finra.dm.dao.impl.SqsOperationsImpl.java

License:Apache License

@Override
public void sendSqsTextMessage(ClientConfiguration clientConfiguration, String queueName, String messageText) {
    try {//from w  ww  .  j  a va 2  s  .c o m
        AmazonSQSClient amazonSQSClient = new AmazonSQSClient(clientConfiguration);
        GetQueueUrlResult queueUrlResult = amazonSQSClient.getQueueUrl(queueName);
        amazonSQSClient.sendMessage(queueUrlResult.getQueueUrl(), messageText);
    } catch (QueueDoesNotExistException ex) {
        throw new IllegalStateException(String.format("AWS SQS queue with \"%s\" name not found.", queueName),
                ex);
    }
}

From source file:org.juneja.eventdemo.utils.AmazonSimpleQueueService.java

License:Open Source License

public static void main(String[] args) throws Exception {

    /*/*from   w  w  w .j a  v  a2s.c  o  m*/
     * The ProfileCredentialsProvider will return your [default]
     * credential profile by reading from the credentials file located at
     * (~/.aws/credentials).
     */
    AWSCredentials credentials = null;
    try {
        credentials = new ProfileCredentialsProvider().getCredentials();
    } catch (Exception e) {
        throw new AmazonClientException("Cannot load the credentials from the credential profiles file. "
                + "Please make sure that your credentials file is at the correct "
                + "location (~/.aws/credentials), and is in valid format.", e);
    }

    AmazonSQS sqs = new AmazonSQSClient(credentials);
    Region usWest2 = Region.getRegion(Regions.DEFAULT_REGION);
    sqs.setRegion(usWest2);

    System.out.println("===========================================");
    System.out.println("Getting Started with Amazon SQS");
    System.out.println("===========================================\n");

    try {
        // Create a queue
        // System.out.println("Creating a new SQS queue called MyQueue.\n");
        // CreateQueueRequest createQueueRequest = new CreateQueueRequest("TestQueue_EventDriven_2");
        // String myQueueUrl = sqs.createQueue(createQueueRequest).getQueueUrl();

        GetQueueUrlResult queueResult = sqs.getQueueUrl("TestQueue_EventDriven_2");
        String myQueueUrl = queueResult.getQueueUrl();

        // List queues
        System.out.println("Listing all queues in your account.\n");
        for (String queueUrl : sqs.listQueues().getQueueUrls()) {
            System.out.println("  QueueUrl: " + queueUrl);
        }
        System.out.println();

        // Send a message
        //System.out.println("Sending a message to MyQueue.\n");
        //sqs.sendMessage(new SendMessageRequest(myQueueUrl, "This is my new text."));

        // Receive messages
        System.out.println("Receiving messages from MyQueue.\n");
        ReceiveMessageRequest receiveMessageRequest = new ReceiveMessageRequest(myQueueUrl);
        List<Message> messages = sqs.receiveMessage(receiveMessageRequest).getMessages();

        System.out.println("Number of messages : " + messages.size());

        for (Message message : messages) {
            System.out.println("  Message");
            System.out.println("    MessageId:     " + message.getMessageId());
            System.out.println("    ReceiptHandle: " + message.getReceiptHandle());
            System.out.println("    MD5OfBody:     " + message.getMD5OfBody());
            System.out.println("    Body:          " + message.getBody());
            for (Entry<String, String> entry : message.getAttributes().entrySet()) {
                System.out.println("  Attribute");
                System.out.println("    Name:  " + entry.getKey());
                System.out.println("    Value: " + entry.getValue());
            }
        }
        System.out.println();

        // Delete a message
        //System.out.println("Deleting a message.\n");
        //String messageRecieptHandle = messages.get(0).getReceiptHandle();
        //sqs.deleteMessage(new DeleteMessageRequest(myQueueUrl, messageRecieptHandle));

        // Delete a queue
        /**
        System.out.println("Deleting the test queue.\n");
        sqs.deleteQueue(new DeleteQueueRequest(myQueueUrl));
        **/
    } catch (AmazonServiceException ase) {
        System.out.println("Caught an AmazonServiceException, which means your request made it "
                + "to Amazon SQS, but was rejected with an error response for some reason.");
        System.out.println("Error Message:    " + ase.getMessage());
        System.out.println("HTTP Status Code: " + ase.getStatusCode());
        System.out.println("AWS Error Code:   " + ase.getErrorCode());
        System.out.println("Error Type:       " + ase.getErrorType());
        System.out.println("Request ID:       " + ase.getRequestId());
    } catch (AmazonClientException ace) {
        System.out.println("Caught an AmazonClientException, which means the client encountered "
                + "a serious internal problem while trying to communicate with SQS, such as not "
                + "being able to access the network.");
        System.out.println("Error Message: " + ace.getMessage());
    }
}

From source file:org.springframework.cloud.aws.messaging.support.destination.DynamicQueueUrlDestinationResolver.java

License:Apache License

@Override
public String resolveDestination(String name) throws DestinationResolutionException {
    if (isValidQueueUrl(name)) {
        return name;
    }//www.j a  v  a  2  s .co  m

    if (this.resourceIdResolver != null) {
        String physicalResourceId = this.resourceIdResolver.resolveToPhysicalResourceId(name);
        if (!name.equals(physicalResourceId)) {
            // name was resolved otherwise it would be equal
            return physicalResourceId;
        }
    }

    if (this.autoCreate) {
        //Auto-create is fine to be called even if the queue exists.
        CreateQueueResult createQueueResult = this.amazonSqs.createQueue(new CreateQueueRequest(name));
        return createQueueResult.getQueueUrl();
    } else {
        try {
            GetQueueUrlResult getQueueUrlResult = this.amazonSqs.getQueueUrl(new GetQueueUrlRequest(name));
            return getQueueUrlResult.getQueueUrl();
        } catch (QueueDoesNotExistException e) {
            throw new DestinationResolutionException(e.getMessage(), e);
        }
    }
}

From source file:se.symsoft.codecamp.SmsGeneratorService.java

License:Open Source License

private HttpServer start() throws IOException {
    AmazonDynamoDBClient amazonDynamoDBClient = new AmazonDynamoDBClient().withRegion(Regions.EU_WEST_1);
    dynamoDB = new DynamoDBMapper(amazonDynamoDBClient);

    sqsClient = new AmazonSQSClient().withRegion(Regions.EU_WEST_1);
    String queueName = System.getenv("SQS_QUEUE_NAME");
    System.out.println("SQS_QUEUE_NAME = " + queueName);
    GetQueueUrlResult result = sqsClient.getQueueUrl(queueName);
    queueUrl = result.getQueueUrl();
    SqsMessageReceiver sqsMessageReceiver = new SqsMessageReceiver(this, sqsClient, queueName);
    new Thread(sqsMessageReceiver).start();

    Metrics.startGraphiteMetricsReporter();

    URI baseUri = UriBuilder.fromUri("http://0.0.0.0/").port(8070).build();

    HttpServer server = GrizzlyHttpServerFactory.createHttpServer(baseUri, this);
    server.getServerConfiguration().addHttpHandler(
            new CLStaticHttpHandler(SmsGeneratorService.class.getClassLoader(), "web/"), "/generator-ui");
    server.start();//from  ww  w  . j  a  va2  s  . c o m
    return server;
}