IamCalvinBrown.com a Blog Site

Code Examples, Consulting Advice and lots of other cool things

Check to see if an S3 object exists

In Amazon S3 we sometimes need to check for the existence of an object (picture, file, etc) before taking the next actions. Here's how we do it in C#. If we find anything that matches, it brings it bk in a list.

Note: The variables App.awsKey & App.awsSecretyKey are my global variables in my Xamarin forms app. You should replace these with the text values for your key and secretKey from your AWS account.

Note: Prefix = key (key is just a string -- the name of the object you want to find)

Amazon.S3.AmazonS3Client s3Client = new Amazon.S3.AmazonS3Client(App.awsKey, App.awsSecretKey, Amazon.RegionEndpoint.USEast1);


            var request = new ListObjectsRequest

            {

                Prefix = key,

                MaxKeys = 1

            };

            ListObjectsResponse response = await s3Client.ListObjectsAsync(request);

            if (response.S3Objects.Count == 0)

            {

                return false;

            }

            return true;

Send a text message (SMS) using Amazon SNS

(This assumes you've already setup the topic and have your own Topic ARN)


using Amazon.SimpleNotificationService;

using Amazon.SimpleNotificationService.Model;

// be sure this is the region you're choosing

AmazonSimpleNotificationServiceClient client = new AmazonSimpleNotificationServiceClient(Amazon.RegionEndpoint.USEast1);

// Publish a message to an Amazon SNS topic.

PublishRequest publishRequest = new PublishRequest("arn:aws:sns:us-east-1:123456:TESTTOPIC","this is the message");

var publishResponse = await client.PublishAsync(publishRequest);

AWS Connect to SQL Server using Lambda

/* there's a package that needs to be uploaded -- email calvin@kairuconsulting.com for this package. It's a zip that can be uploaded to AWS Lambda  */

const sql = require('mssql');

exports.handler = function(event, context, callback) {   

    const config = {

        user: 'your_user',

        password: 'your_password',

        server: 'abcd1234.us-east-1.rds.amazonaws.com',

        database: 'AdventureWork'

    };

    sql.connect(config, (err) => {

    

    if (err) 

    {

      console.log('Error ' + err);

      callback(err);

    } 

    else 

    {

        const req = new sql.Request();

        req.query('SELECT * FROM your_table', (error, result) => {

        if (error) 

        {

          console.log('Error' + error);

          callback(error);

        } 

        else 

        {

          console.log('Result' + result);

          sql.close();

          callback(null, result.recordset);

        }

      });

    }

  });

    

    //callback(null, "some success message");

};


AWS CLI - Delete all files matching a filter in an S3 bucket

Amazon AWS can be amazing and interesting to deal with at times. When you host a static website using S3 and Route 53, it sometimes creates files for each request the service receives. To purge these files and avoid having tens of thousands or even millions of useless files, use this command on your local CLI:

#Delete all files that name start with "2018" files from the bucket:

aws s3 rm s3://[your-aws-bucket-name]/ --recursive --exclude '*' --include '2018*'

Google Big Query - Patents DB

#standardSQL

SELECT

publication_number,

publication_date,

claims.text,

abstract.text as ab_text

FROM

  `patents-public-data.patents.publications_201710`,

  UNNEST(claims_localized) AS claims,

  UNNEST(abstract_localized) AS abstract

LIMIT  10

Run the same app twice on a MAC

Many of us have the need to run the same app twice. Especially during development testing. If you're like me, you'd like to see the iPad and iPhone versions of the app side-by-side. It's possible, and there's only 1 line required to make that happen.


open -n -a "APPLICATION NAME"

ex: open -n -a "Visual Studio"


You're welcome

What device am I on? - Xamarin Forms


When a customer uses their tablet versus their phone, your app may appear less than stellar. Here's the code necessary to determine which device your app is running on and make changes to item sizes (ex: fonts, spacing, etc) to make your app appear made for all devices.

if ( Device.Idiom == TargetIdiom.Tablet)

{

        // perform all operations tablet related

}

What to Look for When Hiring for DevOps Jobs


Calvin Brown is the DevOps Architect & Lead Developer for Kairu Consulting, LLC.

“The most important things to look for in both developers and operations persons (DevOps) is…”

How much they know about the other areas of the project. To explain, a project consists of these 3 elements: what the user sees, the code that runs, and the platform(s) that it runs on. That’s also usually broken into 3 careers: graphics, developers, and operations.

A good developer would know how to release their product to the world and how to check for security vulnerabilities, deploy machines, and use some of the same tools as the operations team. True, this is two career paths, but consultants like myself who must deliver a product online for our customers to see (and pay for) must know the basics of operations. The same is true for operations folks. Knowing how to build the code for release, write basic scripts, and deploy code is critical in today’s environment. The Cloud (especially Amazon AWS) makes this more of a reality. If a developer says they use AWS and understand EC2, they’re DevOps types of guys (and ladies). If operations candidates know CI/CD (continuous integration/continuous deployment), then they’re likely DevOps ready as well.

(original article available on Stackify at http://bit.ly/2xMas4k )