Project Overview
Stay on top of the game!This project is a real time NBA Game Day Notifications System that delivers live score updates straight to your inbox or phone via SMS/Email. Built using AWS Services and NBA APIs, it showcases how to design a secure, scalable, and automated cloud-based notification system. Perfect for sports enthusiasts and techies exploring AWS and Python-based solutions.
Key Features
- Live Score Updates: Fetches live NBA scores from the NBA Game API.
- Real-Time Notifications: Sends formatted updates via Amazon SNS (SMS/Email).
- Automated Scheduling: Uses Amazon EventBridge for regular updates.
- Security-Focused Design: Implements the principle of least privilege for AWS IAM roles.
Tech Stack
- Cloud Provider: AWS
- Core Services: Amazon SNS, AWS Lambda, EventBridge
- API: NBA Game API from SportsData.io
- Language: Python 3.x
- Security: Custom IAM policies for secure integration
Architecture Overview
- Amazon EventBridge: Automates scheduling of the Lambda function to fetch live game data.
- AWS Lambda: Executes the notification logic in real time.
- Amazon SNS: Sends game day updates to users via SMS and Email.
Project Structure
game-day-notifications/
├── src/
│ ├── gd_notifications.py # Main Lambda function code
├── policies/
│ ├── gd_sns_policy.json # SNS publishing permissions
│ ├── gd_eventbridge_policy.json # EventBridge to Lambda permissions
│ └── gd_lambda_policy.json # Lambda execution role permissions
├── .gitignore
└── README.md # Project documentation
Getting Started
-
Prerequisites
- NBA API Key: Get your free API key from SportsData.io
- AWS Account: Familiarity with AWS services and Python is a plus!
-
Clone the Repository
git clone git@github.com:adesegunasunmo/Game-Day-Notifications.git
cd Game-Day-Notifications
Step-by-Step Setup
Create an SNS Topic
- Open the AWS Management Console.
- Navigate to the SNS service.
- Click Create Topic and select Standard as the topic type.
- Name the topic (e.g., gd_topic) and note the ARN.
- Click Create Topic.
Add Subscriptions to the SNS Topic
- After creating the topic, click on the topic name from the list.
- Navigate to the Subscriptions tab and click Create subscription.
-
Select a Protocol: For Email:
- Choose Email.
- Enter a valid email address.
- For SMS (phone number):
- Choose SMS.
- Enter a valid phone number in international format (e.g., +1234567890).
Click Create Subscription.
If you added an Email subscription:
Check the inbox of the provided email address.
Confirm the subscription by clicking the confirmation link in the email.
For SMS, the subscription will be immediately active after creation.
Create an SNS Topic Policy
- Open the IAM service in the AWS Management Console.
- Navigate to Policies → Create Policy.
- Click JSON and paste the JSON policy from gd_sns_policy.json file
- Replace REGION and ACCOUNT_ID with your AWS region and account ID.
- Click Next: Tags (you can skip adding tags).
- Click Next: Review.
- Enter a name for the policy (e.g., gd_sns_policy).
- Review and click Create Policy.
Create an IAM Role for Lambda
- Open the IAM service in the AWS Management Console.
- Click Roles → Create Role.
- Select AWS Service and choose Lambda.
- Attach the following policies:
- SNS Publish Policy (gd_sns_policy) (created in the previous step).
- Lambda Basic Execution Role (AWSLambdaBasicExecutionRole) (an AWS managed policy).
- Click Next: Tags (you can skip adding tags).
- Click Next: Review.
- Enter a name for the role (e.g., gd_role).
- Review and click Create Role.
- Copy and save the ARN of the role for use in the Lambda function.
Deploy the Lambda Function
- Open the AWS Management Console and navigate to the Lambda service.
- Click Create Function.
- Select Author from Scratch.
- Enter a function name (e.g., gd_notifications).
- Choose Python 3.x as the runtime.
- Assign the IAM role created earlier (gd_role) to the function.
- Under the Function Code section:
- Copy the content of the src/gd_notifications.py file from the repository.
- Paste it into the inline code editor.
- Under the Environment Variables section, add the following:
- NBA_API_KEY: your NBA API key.
- SNS_TOPIC_ARN: the ARN of the SNS topic created earlier.
- Click Create Function.
Automate with Eventbridge
- Navigate to the Eventbridge service in the AWS Management Console.
- Go to Rules → Create Rule.
- Select Event Source: Schedule.
- Set the cron schedule for when you want updates (e.g., hourly).
- Under Targets, select the Lambda function (gd_notifications) and save the rule.
Testing the System
- Open the Lambda function in the AWS Management Console.
- Create a test event to simulate execution.
- Run the function and check CloudWatch Logs for errors.
- Verify that SMS notifications are sent to the subscribed users.
What I Learned
- Setting up a cloud-based notification system with AWS SNS and Lambda.
- Best practices for securing AWS resources with IAM..
- Integrating third-party APIs into serverless workflows.
- Automating tasks with EventBridge and Lambda.
Remember to delete all the resources you created on AWS once you’re done so as not to incur any costs!
Thank you for reading, and I hope you found this guide helpful. Keep learning and building!
Top comments (0)