Monday, May 5, 2025

Hello Typescript world

Typescript is javascript with type. Waita minute the very reason you use javascript (rather than java) is you want to be quick-and-dirty and not want to use types right? Well if you want to use React with types you will need Typescript. Its syntax is somewhat like Pascal: See https://www.geeksforgeeks.org/hello-world-in-typescript-language/ for a quick introduction. But in React you don't compile and run. It's mostly automatic. and you are likely not going to do a lot of heavy OOP either.

Search for "react typescript hello world" and you will find several ways to do that. I use npm. First you need to install node. Then create skeleton app:

npx create-react-app my-app --template typescript
Then go to the folder
cd my-app
A bunch of things has been generated for you. Go to src/App.tsx. This is where you put your components.

Here is a simple component. Call it MyComponentFC.tsx

import React from 'react';

const MyComponentFC: React.FC<{
  name: string;
  age: number}> = ({name,age}) => {

  return (
    <h1>Hello, {name}! you are {age} years old</h1>
  );
};

export default MyComponentFC;

In React instead of making things public you "export" it so it is known to outside world. Yes, people like returning not a single value these days. People don't mind mixing code with HTML in a giant return statement. You are cranky old school if you think this isn't so elegant.

See this little component (not a class, but a constant function) takes 2 parameters and you can give each a type (and you have to repeat the names in that interesting symtax). The parameters can be much more complex than strings and numbers. The idea is define your own tags and manage states (variables) within.

This simple component generates some simple html with parameters you passed in.

That index.html is what your browser hits... which in turns calls index.tsx, which calls the App component. Here is my tweaked App.tsx to call that component. FC stands for Function Component.

import './App.css';
import MyComponentFC from './MyComponentFC';

function App() {
  return (
      <MyComponentFC name="Johnny" age={20}/>
      )
}

export default App;

Launch the app with

npm start

Monday, February 3, 2025

Hello boto3 world

Boto3 is the library for interacting with AWS via Python. https://boto3.amazonaws.com/v1/documentation/api/latest/index.html

Need to first install:

pip3 install boto3
Lots of examples are out there but they are not yours unless you get it to work for you. So to get started you need an AWS account, and credentials be setup in your local machine. https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html

So I have a couple files on S3 in a bucket, and I can retrieve them. Sometimes boto3 is better than other languages because sometimes other languages such as Java may be more clumsy.

import boto3
from botocore.exceptions import ClientError

def getContentInBucket(s3_client, bucketName):
   result = s3_client.list_objects(Bucket = bucketName, Prefix='')
   for o in result.get('Contents'):
      print("fileName: "+o.get('Key'))
      data = s3_client.get_object(Bucket=bucketName, Key=o.get('Key'))
      contents = data['Body'].read()
      print(contents.decode("utf-8"))

# To get list of buckets present in AWS using S3 client
def get_buckets_client(s3_client):
   try:
      response = s3_client.list_buckets()
   
      for bucket in response['Buckets']:
         bucketName = bucket["Name"]
         print("bucketName: "+bucketName)
         getContentInBucket(s3_client, bucketName)

   except ClientError:
      print("Couldn't get buckets.")
      raise
   
session = boto3.session.Session()

# User can pass customized access key, secret_key and token as well
# credentials are set in my .aws/credentials file
# See https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html
s3_client = session.client('s3')

get_buckets_client(s3_client);