DropboxのWebhook通知の中身が空っぽになる件

Dropboxアプリを開発中ですが、上手くいきません。

実現したいこと

-Dropboxに画像をアップロードするとWebhookでAWS API Gatewayに通知。
-AWS API GatewayからLambdaを起動する。
-Lambdaでは、Dropboxにアップロードした画像をS3にコピーし、AWS textractで文字情報を抽出する。

前提

・Dropboxは無料版で使ってます。
・自分のライフハックのためで、公開する予定はないです。

発生している問題・エラーメッセージ

画像をアップロードするとWebhookにより、Lambda関数の起動まではうまくいきましたが、Dropboxからのリクエストの中身が空っぽになっており、原因がわからずに困ってます。

LambdaLog

1event: 2{'delta': '{}', 'list_folder': '{}'}

python

1### 該当のソースコード2import json 3import boto3 4import base64 5 6s3_client = boto3.client('s3')7textract_client = boto3.client('textract')8 9def lambda_handler(event, context):10 print("event:")11 print(event)12 print("context:")13 print(context)14 """ 一旦コメントアウト 15 # Dropboxから送られたWebhooksリクエストを取得する 16 data = json.loads(event['body']) 17 print(data) 18 19 # アップロード先のS3バケット名とオブジェクトキー 20 s3_bucket_name = 'xxx' 21 s3_object_key = 'yyy' 22 23 # ファイルの内容を取得する 24 file_contents = base64.b64decode(data['content']) 25 26 # ファイルをS3に保存する 27 s3_client.put_object(Bucket=s3_bucket_name, Key=s3_object_key, Body=file_contents) 28 29 # S3に保存されたファイルをAmazon Textractに渡してOCRを実行する 30 response = textract_client.detect_document_text(Document={'S3Object': {'Bucket': s3_bucket_name, 'Name': s3_object_key}}) 31 32 # OCR結果をログに出力する 33 print(response) 34 """35 36 # レスポンスを返す37 return {38 'statusCode': 200,39 'body': json.dumps('OCR complete')40 }

試したこと

APIGatewayでマッピングテンプレートをいじったりしましたが、APIGatewayのログをみると、APIGatewayの時点で空っぽに見えます。

APIGatewayLog

1Method request body before transformations: 2{ 3 "delta": {}, 4 "list_folder": {} 5}

補足情報(FW/ツールのバージョンなど)

・Dropboxのアプリコンソール上で、Permissionsはオールチェック済みです。
イメージ説明

参考

公式ドキュメント:
https://www.dropbox.com/developers/reference/webhooks#webhooks
類似の質問?:
https://stackoverflow.com/questions/38775488/dropbox-api-php-notification-request-is-empty

コメントを投稿

0 コメント