GoogleForm,GASからAPI Gateway, Lambdaで入力情報をDynamoDBに格納する
2021/06/12
vol.26 AWS認定試験テキスト認定クラウドプラクティショナーのデモ(DynamoDB)で、DynamoDBのテーブル作成からデータの検索などのデモをしようと思うのですが、せっかくなので参加されるみなさんにデータを作ってもらおうと思いまして、GoogleFormから連携するようにしました。
データが流れる順番で解説を書きますが、実装する際は逆順になりますのでご注意ください。
目次
Google Apps Script
フォーム回答のGoogleスプレッドシートで[ツール]-[スクリプトエディタ]を選択しました。
名前をデフォルトから変更しました。
eventをそのまま、API Gatewayで作成したAPIへPOSTしました。
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
function ddbdemo(event) { console.log(event); var parameters = { 'method': 'post', 'contentType': 'application/json', 'payload': JSON.stringify(event) }; var api_endpoint = 'https://xxxxxxxx.execute-api.us-east-1.amazonaws.com/v1/food'; var response = UrlFetchApp.fetch(api_endpoint, parameters); console.log(response); } |
[実行]ボタンから手動で実行して権限付与しておきました。
トリガーアイコンでトリガーメニューに遷移して、[トリガーを追加]ボタンから、スプレッドシートのフォーム送信時を選択しました。
実行数メニューで実行ログを確認できました。
Amazon API Gateway
POST, GET, GET(GSI)を用意しましたが、すべてLambdaプロキシ統合を使用しました。
AWS Lambda
POSTの例
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
import json import boto3 def lambda_handler(event, context): body = json.loads(event['body']) namedValues = body.get('namedValues') id = namedValues.get('ID')[0] date = namedValues.get('日付')[0] satisfaction = int(namedValues.get('満足度')[0]) repeat = namedValues.get('もう一度食べたい')[0] menu = namedValues.get('メニュー')[0] item = { 'id': id, 'date': date, 'satisfaction': satisfaction, 'menu': menu } if repeat == '食べたい': item['repeat'] = 'y' table = boto3.resource('dynamodb').Table('food') response = table.put_item( Item = item ) return { 'statusCode': 200, 'body': json.dumps(response) } |
namedValuesにGoogleフォームに入力された値が配列で格納されているので必要な値を取得して、DynamoDBテーブルにPutItemしています。
GETの例
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
import json import boto3 from boto3.dynamodb.conditions import Key from decimal import Decimal def decimal_default_proc(obj): if isinstance(obj, Decimal): return float(obj) raise TypeError def lambda_handler(event, context): print(event) table = boto3.resource('dynamodb').Table('food') response = table.query( KeyConditionExpression=Key('id').eq(event['queryStringParameters']['id']) ) return { 'statusCode': 200, 'body': json.dumps(response['Items'], default=decimal_default_proc) } |
URLクエリで検索するAPIですので、queryStringParametersのキーを渡しています。
decimal型が含まれているとjson.dumpsでエラーになるので、float型に変換しています。
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
import json import boto3 from boto3.dynamodb.conditions import Key from decimal import Decimal def decimal_default_proc(obj): if isinstance(obj, Decimal): return float(obj) raise TypeError def lambda_handler(event, context): table = boto3.resource('dynamodb').Table('food') response = table.query( IndexName='repeat-index', KeyConditionExpression=Key('repeat').eq('y') ) return { 'statusCode': 200, 'body': json.dumps(response['Items'], default=decimal_default_proc) } |
IndexNameで’repeat-index’グローバルセカンダリインデックス(GSI)を指定しています。
Amazon DynamoDB
デモで用意したテーブルです。
テーブル名: food
パーティションキー: id(文字列)
ソートキー: date(文字列)
ローカルセカンダリインデックス(LSI):
ソートキー: satisfaction(数字)
グローバルセカンダリインデックス(GSI):
パーティションキー: repeat
デモで必要なデータを参加されたみなさんに作っていただけると、デモデータの準備に時間を割かなくていいし、ちょっとだけ参加型のデモになってよかったです。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。
「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。
「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。
「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。
「AWSではじめるLinux入門ガイド」という本を書きました。
開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
SageMaker AI StudioでJupyterLab スペースを作成しJupyterLab を起動、S3拡張のインストール
JupyterLab ユーザーガイドとJupyterLab 拡張機能を参照して、 …
-
-
AWS License ManagerでAMIからインスタンスの起動を制御
EC2 Image BuilderでRocket.ChatのAMIを作って起動テ …
-
-
JAWS-UG関西「AI で人を笑わせてみよう!ハンズオン」に参加しました
AI で人を笑わせてみよう!ハンズオン 灼熱の7月最終日にJAWS-UG関西のオ …
-
-
S3バケットポリシーでクロスアカウントのPrincipalについて確認
確認したこと ドキュメントではこちらで確認しました。 AWS JSON ポリシー …
-
-
CloudFrontディストリビューションを別アカウントへ移動する
すでにCNAMEを設定しているCloudFrontディストリビューションを、別ア …
-
-
Amazon CloudSearchにAWS Lambda(Python)からデータをアップロードする
このブログはゆるっとアドベントカレンダー Advent Calendar 201 …
-
-
php-fpm で Out of memoryが発生した際にメール通知する(AWS CloudWatch , Amazon SNS)
AWS CloudWatch LogsエージェントでAmazon EC2上のNg …
-
-
AWS Trusted Advisorの2023/11/17発表のAPI
2023/11/17に発表されたAWS Trusted Advisor の新しい …
-
-
AWS Organizations SCPがリソースベースのポリシーには影響しないことを確認
AWS Organizations SCPで許可ポリシーの設定をし継承の関係を確 …
-
-
AWS Systems Manager Session ManagerでLinuxインスタンスのRun Asサポートを有効にする
AWS Systems Manager Session Managerの設定画面 …






