

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# aws-s3ステップ関数
<a name="aws-s3-step-function"></a>

![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/experimental.png)


 すべてのクラスは積極的に開発されており、将来のバージョンでは下位互換性がない変更または削除の対象となります。これらは対象外です[セマンティックバージョニング](https://semver.org/)モデル。つまり、これらのパッケージを使用するかもしれませんが、このパッケージの新しいバージョンにアップグレードするときにソースコードを更新する必要があるかもしれません。

**注意:** 正しく機能するためには、プロジェクト内の AWS ソリューション構築パッケージと AWS CDK パッケージが同じバージョンである必要があります。


|  **言語**  |  **パッケージ**  | 
| --- | --- | 
|  ![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/python.png) Python  |  aws\_solutions\_constructs.aws\_s3\_step\_function  | 
|  ![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/typescript.png) TypeScript  |  @aws-solutions-constructs/aws-s3-step-function  | 
|  ![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/java.png) Java  |  software.amazon.awsconstructs.services.s3stepfunction  | 

## Overview
<a name="overview-22"></a>

 この AWS ソリューション構築物は、AWS ステップ関数に接続された Amazon S3 バケットを実装します。

**注記**  
この構造体は、Amazon EventBridge（Amazon CloudWatch Events）を使用して AWS Step Functions をトリガーします。EventBridge はより柔軟ですが、S3 イベント通知を使用してStep Functions をトリガーするレイテンシーが少なく、費用対効果が高くなります。コストやレイテンシーに問題がある場合は、`aws-s3-lambda`および`aws-lambda-stepfunctions`この構成要素の代わりに。

 TypeScript の最小限のデプロイ可能なパターン定義は次のとおりです。

```
import { S3ToStepFunction, S3ToStepFunctionProps } from '@aws-solutions-constructs/aws-s3-step-function';
import * as stepfunctions from '@aws-cdk/aws-stepfunctions';

const startState = new stepfunctions.Pass(this, 'StartState');

new S3ToStepFunction(this, 'test-s3-step-function-stack', {
    stateMachineProps: {
      definition: startState
    }
});
```

## Initializer
<a name="initializer-22"></a>

```
new S3ToStepFunction(scope: Construct, id: string, props: S3ToStepFunctionProps);
```

 *パラメータ* 
+  scope[https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html) 
+  id`string` 
+  props[`S3ToStepFunctionProps`](#pattern-construct-props-22) 

## パターン構成プロパティ
<a name="pattern-construct-props-22"></a>


|  **名前**  |  **タイプ**  |  **説明**  | 
| --- | --- | --- | 
|  ExistingBucketObj？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.IBucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.IBucket.html)  |  S3 Bucket オブジェクトの既存のインスタンス。これが提供されている場合は、bucketPropsはエラーです。 | 
|  BucketProps？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.BucketProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.BucketProps.html)  |  オプションのユーザー提供のプロパティ。バケットのデフォルトプロパティを上書きします。の場合は無視されますexistingBucketObjが提供される。 | 
|  ステートメントマシンプロップ  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-stepfunctions.StateMachineProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-stepfunctions.StateMachineProps.html)  |  sfn.stateMachine のデフォルトプロップを上書きするオプションのユーザ提供の小道具です。 | 
|  EventRuleProps？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-events.RuleProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-events.RuleProps.html)  |  オプションのユーザーがデフォルトを上書きするために EventRuleProps を提供しました。 | 
|  デプロイクラウドトレイル？  |  boolean  |  AWS CloudTrail でトレイルをデプロイして、Amazon S3 で API イベントを記録するかどうか。デフォルトは true です。 | 
|  クラウド・ワット・チャラームズ  |  boolean  |  推奨される CloudWatch アラームを作成するかどうか。 | 
|  LogGroupProps？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-logs.LogGroupProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-logs.LogGroupProps.html)  |  CloudWatch Logs ロググループのデフォルトの小道具を上書きする、オプションのユーザー提供の小道具です。 | 

## パターンプロパティ
<a name="pattern-properties-22"></a>


|  **名前**  |  **タイプ**  |  **説明**  | 
| --- | --- | --- | 
|  cloudtrail? |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudtrail.Trail.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudtrail.Trail.html)  |  パターンによって作成されたCloudtrailトレイルのインスタンスを返します。 | 
|  CloudTrailBucket？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html)  |  Cloudtrail トレイルデータを格納するためにパターンによって作成されたバケットのインスタンスを返します。 | 
|  CloudTrailLoggingBucket？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html)  |  Cloudtrail トレイルで使用されるプライマリバケットのパターンによって作成されたロギングバケットのインスタンスを返します。 | 
|  CloudWatchAlarms？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudwatch.Alarm.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudwatch.Alarm.html)  |  パターンによって作成される 1 つまたは複数の CloudWatch アラームのリストを返します。 | 
|  S3bucket？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html)  |  パターンによって作成された S3 バケットのインスタンスを返します。 | 
|  s3loggingBucket？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html)  |  S3 バケットのパターンによって作成されたロギングバケットのインスタンスを返します。 | 
|  StateMachine  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-stepfunctions.StateMachine.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-stepfunctions.StateMachine.html)  |  パターンによって作成されたステートマシンのインスタンスを返します。 | 
|  ステートメントマシンロググループ  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-logs.LogGroup.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-logs.LogGroup.html)  |  ステートマシンのパターンによって作成されたロググループのインスタンスを返します。 | 

## デフォルト設定
<a name="default-settings-22"></a>

 オーバーライドなしでこのパターンをすぐに実装すると、次のデフォルトが設定されます。

### Amazon S3 バケット
<a name="amazon-s3-bucket-6"></a>
+  S3 バケットのアクセスログを設定します。
+  AWS マネージド KMS キーを使用して S3 バケットのサーバー側の暗号化を有効にします。
+  S3 バケットのバージョニングを有効にします。
+  S3 バケットのパブリックアクセスを許可しません。
+  CloudFormation スタックを削除するときは、S3 バケットを保持します。
+  転送時のデータの暗号化を強制します。
+  90 日後に Glacier ストレージに最新でないオブジェクトバージョンを移動するライフサイクルルールを適用します。

### AWS CloudTrail
<a name="aws-cloudtrail"></a>
+  AWS CloudTrail で証跡を設定し、構築によって作成されたバケットに関連する Amazon S3 の API イベントを記録します。

### Amazon CloudWatch Events Events ルール
<a name="amazon-cloudwatch-events-rule-2"></a>
+  CloudWatch イベントに Lambda 関数をトリガーするための最小限の権限を付与します。

### AWS ステップ関数
<a name="aws-step-function-1"></a>
+  API Gateway の CloudWatch ロギングを有効にします。
+  ベストプラクティスの CloudWatch アラームをステップ関数にデプロイします。

## Architecture
<a name="architecture-22"></a>

![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/aws-s3-step-function.png)


## GitHub
<a name="github-22"></a>


<table>
<thead>
  <tr><th colspan="2"> このパターンのコードを表示するには、問題を作成/表示し、プル要求などを行います。 </th></tr>
</thead>
<tbody>
  <tr><td> ![](http://docs.aws.amazon.com/ja_jp/solutions/latest/constructs/images/GitHub-Mark-32px.png) </td><td> [@aws-ソリューション-構築/aws-s3-ステップ関数](https://github.com/awslabs/aws-solutions-constructs/tree/master/source/patterns/%40aws-solutions-constructs/aws-s3-step-function) </td></tr>
</tbody>
</table>
