diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml
index ce23276..7acf17a 100644
--- a/.pre-commit-config.yaml
+++ b/.pre-commit-config.yaml
@@ -4,9 +4,12 @@ repos:
hooks:
- id: terraform_fmt
- id: terraform_docs
+ args:
+ - --args=--output-file=README.md
- id: terraform_checkov
- id: terraform_tflint
- id: terraform_tfsec
- id: terrascan
- id: tfupdate
- # - id: terraform_validate
+ - id: terraform_validate
+
diff --git a/terraform/modules/apigw/README.md b/terraform/modules/apigw/README.md
new file mode 100644
index 0000000..91931a7
--- /dev/null
+++ b/terraform/modules/apigw/README.md
@@ -0,0 +1,54 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_api_gateway_deployment.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_deployment) | resource |
+| [aws_api_gateway_integration.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_integration) | resource |
+| [aws_api_gateway_integration_response.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_integration_response) | resource |
+| [aws_api_gateway_method.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_method) | resource |
+| [aws_api_gateway_method_response.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_method_response) | resource |
+| [aws_api_gateway_resource.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_resource) | resource |
+| [aws_api_gateway_rest_api.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_rest_api) | resource |
+| [aws_api_gateway_stage.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/api_gateway_stage) | resource |
+| [aws_lambda_permission.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/lambda_permission) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [integration](#input\_integration) | Map of API gateway integrations. | `map(any)` | n/a | yes |
+| [integration\_response](#input\_integration\_response) | Map of API gateway method integrations. | `map(any)` | n/a | yes |
+| [lambda](#input\_lambda) | List of lambdas the API will execute. | `list(any)` | n/a | yes |
+| [method](#input\_method) | Map of API gateway methods. | `map(any)` | n/a | yes |
+| [method\_response](#input\_method\_response) | Map of API gateway method response. | `map(any)` | n/a | yes |
+| [name](#input\_name) | The name of the API. | `string` | n/a | yes |
+| [role\_arn](#input\_role\_arn) | ARN of the IAM role (credentials). | `string` | n/a | yes |
+| [sqs\_arn](#input\_sqs\_arn) | ARN of the SQS. | `string` | n/a | yes |
+| [tags](#input\_tags) | A mapping of tags to assign to API gateway resources. | `map(string)` | `{}` | no |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [endpoint](#output\_endpoint) | n/a |
+| [resource\_path](#output\_resource\_path) | n/a |
+| [rest\_id](#output\_rest\_id) | n/a |
+
\ No newline at end of file
diff --git a/terraform/modules/cloudfront/README.md b/terraform/modules/cloudfront/README.md
new file mode 100644
index 0000000..dd772e3
--- /dev/null
+++ b/terraform/modules/cloudfront/README.md
@@ -0,0 +1,39 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_cloudfront_distribution.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/cloudfront_distribution) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [default\_cache\_behavior](#input\_default\_cache\_behavior) | The default cache behavior for this distribution | `any` | n/a | yes |
+| [default\_root\_object](#input\_default\_root\_object) | The object that you want CloudFront to return (for example, index.html) when an end user requests the root URL. | `string` | `null` | no |
+| [enabled](#input\_enabled) | Whether the distribution is enabled to accept end user requests for content. | `bool` | `true` | no |
+| [origin](#input\_origin) | One or more origins for this distribution. | `any` | n/a | yes |
+| [tags](#input\_tags) | A map of tags to assign to the resource. | `map(string)` | `{}` | no |
+| [web\_acl\_id](#input\_web\_acl\_id) | Id or ARN of the AWS WAF web ACL that is associated with the distribution. | `string` | n/a | yes |
+
+## Outputs
+
+No outputs.
+
\ No newline at end of file
diff --git a/terraform/modules/dynamodb/README.md b/terraform/modules/dynamodb/README.md
new file mode 100644
index 0000000..0beafe7
--- /dev/null
+++ b/terraform/modules/dynamodb/README.md
@@ -0,0 +1,43 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_dynamodb_table.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/dynamodb_table) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [attributes](#input\_attributes) | List of nested attribute definitions (used for hash and range key). | `list(map(string))` | `[]` | no |
+| [billing\_mode](#input\_billing\_mode) | Controls how you are billed for read/write throughput and how you manage capacity. | `string` | `"PROVISIONED"` | no |
+| [hash\_key](#input\_hash\_key) | The attribute to use as the hash (partition) key. | `string` | `null` | no |
+| [name](#input\_name) | Name of the DynamoDB table. | `string` | `null` | no |
+| [range\_key](#input\_range\_key) | The attribute to use as the range (sort) key. | `string` | `null` | no |
+| [read\_capacity](#input\_read\_capacity) | The number of read units for this table. | `number` | `20` | no |
+| [tags](#input\_tags) | A map of tags to add to all resources | `map(string)` | `{}` | no |
+| [write\_capacity](#input\_write\_capacity) | The number of write units for this table. | `number` | `20` | no |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [name](#output\_name) | The name of the table. |
+
\ No newline at end of file
diff --git a/terraform/modules/lambda/README.md b/terraform/modules/lambda/README.md
new file mode 100644
index 0000000..f5ddf65
--- /dev/null
+++ b/terraform/modules/lambda/README.md
@@ -0,0 +1,45 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_lambda_function.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/lambda_function) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [function\_name](#input\_function\_name) | A unique name for your Lambda Function. | `string` | n/a | yes |
+| [handler](#input\_handler) | Lambda Function entrypoint in your code. | `string` | n/a | yes |
+| [iam\_role](#input\_iam\_role) | IAM role ARN attached to the Lambda Function. | `string` | n/a | yes |
+| [package](#input\_package) | The absolute path to an existing zip-file to use. | `string` | `null` | no |
+| [runtime](#input\_runtime) | Lambda Function runtime. | `string` | n/a | yes |
+| [source\_arn](#input\_source\_arn) | Lambda source ARN. | `string` | `""` | no |
+| [tags](#input\_tags) | A mapping of tags to assign to API gateway resources. | `map(string)` | `{}` | no |
+| [vpc\_security\_group\_ids](#input\_vpc\_security\_group\_ids) | List of security group ids when Lambda Function should run in the VPC. | `list(string)` | `null` | no |
+| [vpc\_subnet\_ids](#input\_vpc\_subnet\_ids) | List of subnet ids when Lambda Function should run in the VPC. | `list(string)` | `null` | no |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [function\_arn](#output\_function\_arn) | The ARN of the Lambda Function |
+| [function\_name](#output\_function\_name) | The name of the Lambda Function |
+
\ No newline at end of file
diff --git a/terraform/modules/s3/README.md b/terraform/modules/s3/README.md
new file mode 100644
index 0000000..6cbefa5
--- /dev/null
+++ b/terraform/modules/s3/README.md
@@ -0,0 +1,52 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_s3_bucket.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_bucket) | resource |
+| [aws_s3_bucket_acl.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_bucket_acl) | resource |
+| [aws_s3_bucket_logging.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_bucket_logging) | resource |
+| [aws_s3_bucket_policy.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_bucket_policy) | resource |
+| [aws_s3_bucket_website_configuration.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_bucket_website_configuration) | resource |
+| [aws_s3_object.index](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_object) | resource |
+| [aws_s3_object.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/s3_object) | resource |
+| [aws_iam_policy_document.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [block\_public\_access](#input\_block\_public\_access) | Determines the S3 account-level Public Access Block configuration. | `bool` | `true` | no |
+| [bucket\_acl](#input\_bucket\_acl) | The canned ACL to apply. Valid values are private, public-read, public-read-write, aws-exec-read, authenticated-read, and log-delivery-write. Defaults to private. | `string` | `"private"` | no |
+| [bucket\_name](#input\_bucket\_name) | The name of the bucket. Must be less than or equal to 63 characters in length. | `string` | n/a | yes |
+| [content](#input\_content) | Website bucket content. | `string` | n/a | yes |
+| [objects](#input\_objects) | Map of objects to upload to the bucket. | `map(any)` | `{}` | no |
+| [type](#input\_type) | Determines the type of the bucket. 1 for static website and 2 for logs. | `number` | `1` | no |
+| [website](#input\_website) | Map that defines the configuration of the website. | `map(any)` | `{}` | no |
+| [website\_id](#input\_website\_id) | Website bucket ID. | `string` | n/a | yes |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [arn](#output\_arn) | The ARN of the bucket. Will be of format arn:aws:s3:::bucketname. |
+| [id](#output\_id) | The bucket domain name. Will be of format bucketname.s3.amazonaws.com. |
+| [website\_endpoint](#output\_website\_endpoint) | The website endpoint, if the bucket is configured with a website. If not, this will be an empty string. |
+
\ No newline at end of file
diff --git a/terraform/modules/sqs/README.md b/terraform/modules/sqs/README.md
new file mode 100644
index 0000000..b3d8f56
--- /dev/null
+++ b/terraform/modules/sqs/README.md
@@ -0,0 +1,47 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_lambda_event_source_mapping.event_source_mapping](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/lambda_event_source_mapping) | resource |
+| [aws_lambda_permission.allows_sqs_to_trigger_lambda](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/lambda_permission) | resource |
+| [aws_sqs_queue.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/sqs_queue) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [content\_based\_deduplication](#input\_content\_based\_deduplication) | Enables content-based deduplication for FIFO queues. | `bool` | `false` | no |
+| [delay\_seconds](#input\_delay\_seconds) | The time in seconds that the delivery of all messages in the queue will be delayed. An integer from 0 to 900 (15 minutes). | `number` | `0` | no |
+| [fifo\_queue](#input\_fifo\_queue) | Boolean designating a FIFO queue. | `bool` | `false` | no |
+| [lambda\_name](#input\_lambda\_name) | The name of the lambda to trigger when a message is queued. | `string` | `null` | no |
+| [max\_message\_size](#input\_max\_message\_size) | The limit of how many bytes a message can contain before Amazon SQS rejects it. An integer from 1024 bytes (1 KiB) up to 262144 bytes (256 KiB). | `number` | `262144` | no |
+| [message\_retention\_seconds](#input\_message\_retention\_seconds) | The number of seconds Amazon SQS retains a message. Integer representing seconds, from 60 (1 minute) to 1209600 (14 days). | `number` | `345600` | no |
+| [name](#input\_name) | This is the human-readable name of the queue. | `string` | n/a | yes |
+| [receive\_wait\_time\_seconds](#input\_receive\_wait\_time\_seconds) | The time for which a ReceiveMessage call will wait for a message to arrive (long polling) before returning. An integer from 0 to 20 (seconds). | `number` | `0` | no |
+| [tags](#input\_tags) | A mapping of tags to assign to all resources. | `map(string)` | `{}` | no |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [name](#output\_name) | The name of the SQS. |
+| [sqs\_arn](#output\_sqs\_arn) | The ARN of SQS. |
+
\ No newline at end of file
diff --git a/terraform/modules/waf/README.md b/terraform/modules/waf/README.md
new file mode 100644
index 0000000..78a0bbf
--- /dev/null
+++ b/terraform/modules/waf/README.md
@@ -0,0 +1,39 @@
+
+## Requirements
+
+| Name | Version |
+|------|---------|
+| [terraform](#requirement\_terraform) | 1.3.4 |
+| [aws](#requirement\_aws) | >= 4.10.0 |
+
+## Providers
+
+| Name | Version |
+|------|---------|
+| [aws](#provider\_aws) | 4.38.0 |
+
+## Modules
+
+No modules.
+
+## Resources
+
+| Name | Type |
+|------|------|
+| [aws_wafv2_web_acl.this](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/wafv2_web_acl) | resource |
+
+## Inputs
+
+| Name | Description | Type | Default | Required |
+|------|-------------|------|---------|:--------:|
+| [name](#input\_name) | This is the human-readable name of the WAF. | `string` | n/a | yes |
+| [rule](#input\_rule) | Map of WAF rules. | `map(any)` | `{}` | no |
+| [scope](#input\_scope) | WAF scope (cloudfront or regional). | `string` | n/a | yes |
+| [tags](#input\_tags) | A mapping of tags to assign to all resources. | `map(string)` | `{}` | no |
+
+## Outputs
+
+| Name | Description |
+|------|-------------|
+| [web\_acl\_arn](#output\_web\_acl\_arn) | The web ACL ARN. |
+
\ No newline at end of file