This serverless app creates an AWS Lambda event source by invoking a given lambda function to monitor tweets returned by a predefined search query. It works by periodically polling the freely available public Twitter API and invoking a lambda function you provide to process the returned tweets.
-
The TweetPoller lambda function is periodically triggered by a CloudWatch Events Rule.
-
A DynamoDB table is used to keep track of a checkpoint, which is the timestamp of the most recent tweet.
-
The poller function calls the public Twitter API and fetches recent tweets matching the specified SearchQuery (provided by the app user).
-
The TweetProcessor lambda function (provided by the app user) is invoked with the received tweets if newer the the previous timestamp.
i. Note, the TweetProcessor function is invoked asynchronously (Event invocation type). The app does not confirm that the lambda was able to successfully process the listings.
-
Create a Twitter Developer Account if you do not already have one and login
-
Go to the app's page on the Serverless Application Repository and click "Deploy"
-
Provide the required app parameters (see below for steps to create Twitter API parameters, e.g., Consumer API Key)
The app requires the following Twitter API parameters: Consumer Key (API Key) and Consumer Secret (API Secret). The following steps walk you through registering the app with your Twitter account to create these values.
-
Create a Twitter account if you do not already have one
-
Create a new application.
i.Go to https://developer.twitter.com/en/apps/create
ii. Fill out required fields and click "Create"
-
Get API Key:
i. After creating your application, go to the applications page and click on "Details" next to your new application.
ii. Click on the "Keys and tokens" tab at the top of the page.
iii. Your keys are listed under "Consumer API Keys".
-
(Optional) Limit Permissions
i. For added security, click the "Permissions" tab at the top of the screen.
ii. Click "Edit" and then select the "Read-only" radio button.
iii. Click "Save".
Once you've created your Twitter API keys, you can copy it as plain text into the ConsumerApiKey and ConsumerApiSecretKey parameters of the serverless application. However, it is highly recommended that you do NOT pass these values in as plain text and instead encrypt them using an AWS Key Management Service (KMS) key. Once encrypted, you put the encrypted values into the EncryptedConsumerApiKey and EncryptedConsumerApiSecretKey parameters and provide the DecryptionKeyName parameter as well. The reason the plain text fields are provided at all is so this app can be used in regions that do not support AWS KMS.
The following subsections walk you through how to create a KMS key using the AWS console and encrypt your Twitter API Keys using the AWS CLI.
-
Login to the AWS IAM console.
-
Click the "Encryption keys" menu item.
-
(Important) Just below the "Create key" button, there will be a Region selected. Change this to be the same region that you will deploy your app to.
-
Click "Create key".
-
Enter an alias, e.g., "twitter-api" and click "Next Step".
-
Click "Next Step" again to skip the add tags step.
-
Select a role that is allowed to administer the key, e.g., delete it, and click "Next Step".
-
Select a role that is allowed to use the key, e.g., encrypt with it, and click "Next Step".
-
Preview the key policy and then click "Finish".
-
Click on your newly created key and copy its full ARN value.
-
Install the AWS CLI.
-
Encrypt your Twitter Consumer API Key by running this command:
aws kms encrypt --key-id <key ARN> --plaintext '<Twitter Consumer API key>'
-
The result JSON will contain a field called
CiphertextBlob
. That string value (without the double-quotes) is what should be provided into the EncryptedConsumerApiKey parameter of the serverless app. -
Repeat for these step for the EncryptedConsumerApiSecretKey.
In addition to the Twitter Consumer API Key parameters, the app also requires some of the following parameters:
-
SearchQuery (required) - This is the search query to be used to select which tweets from the last 7 days will be returned.
i. Please note that this string should not be URL encoded, the app will take care of that.
ii. A guide on writing search queries can be found here.
-
AdditionalParamters (optional) - Parameters to further refine what tweets are returned by the Twitter API.
i. These should be defined as a query string without the leading
?
.ii. Do not redefine the
q
parameter here!iii. A list of parameters can be found here.
-
ProcessorFunctionName (required) - This is the name (not ARN) of the lambda function that will process tweets gathered by the app.
-
DecryptionKeyName (required if providing encrypted Twitter Consumer API Keys) - This is the KMS key name of the key used to encrypt the Twitter Consumer API Keys parameters. Note, this must be just the key name (UUID that comes after key/ in the key ARN), not the full key ARN. It's assumed the key was created in the same account and region as the app deployment.
-
PollingFrequencyInMinutes (optional) - The frequency at which the lambda will poll the Twitter API (in minutes). Default: 5.
-
PerRequestTimeout (optional) - Milliseconds before any given request to the Twitter API will timeout and give up. Default: 1500.
-
PollTimeout (optional) - Maximum time in seconds to spend on a given polling sesssion. Default: 30.
-
LoggingLevel (optional) - The level of logging desired (
error,warn,info,debug
ortrace
).
Special thanks to AWS Labs and their excellent Twitter Event Source for providing the idea and foundations for this app.