From eeeaed3b3922756e2136c012ee48399fc0924986 Mon Sep 17 00:00:00 2001 From: jbeemster Date: Fri, 2 Feb 2024 17:00:27 +0100 Subject: [PATCH 1/3] Update LICENSE to SLULA (closes #35) --- LICENSE | 257 ++++++++---------------------------- README.md | 23 ++-- main.tf | 2 + templates/user-data.sh.tmpl | 1 + variables.tf | 11 ++ 5 files changed, 82 insertions(+), 212 deletions(-) diff --git a/LICENSE b/LICENSE index 94d6f6f..6abbe69 100644 --- a/LICENSE +++ b/LICENSE @@ -1,202 +1,57 @@ +# Snowplow Limited Use License Agreement - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright 2021-2023 Snowplow Analytics Ltd. - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. \ No newline at end of file +_Version 1.0, January 2024_ + +This Snowplow Limited Use License Agreement, Version 1.0 (the “Agreement”) sets forth the terms on which Snowplow Analytics, Ltd. (“Snowplow”) makes available certain software (the “Software”). BY INSTALLING, DOWNLOADING, ACCESSING, OR USING ANY OF THE SOFTWARE, YOU AGREE TO THE TERMS AND CONDITIONS OF THIS AGREEMENT. IF YOU DO NOT AGREE TO SUCH TERMS AND CONDITIONS, YOU MUST NOT USE THE SOFTWARE. IF YOU ARE RECEIVING THE SOFTWARE ON BEHALF OF A LEGAL ENTITY, YOU REPRESENT AND WARRANT THAT YOU HAVE THE ACTUAL AUTHORITY TO AGREE TO THE TERMS AND CONDITIONS OF THIS AGREEMENT ON BEHALF OF SUCH ENTITY. “Licensee” means you, an individual, or the entity on whose behalf you are receiving the Software. + +## LICENSE GRANT AND CONDITIONS + +**1.1 License.** Subject to the terms and conditions of this Agreement, Snowplow hereby grants to Licensee a non-exclusive, royalty-free, worldwide, non-transferable, non-sublicensable license during the term of this Agreement to: (a) use the Software; (b) prepare modifications and derivative works of the Software; and (c) reproduce copies of the Software (the “License”). No right to distribute or make available the Software is granted under this License. Licensee is not granted the right to, and Licensee shall not, exercise the License for any Excluded Purpose. + +**1.2** For purposes of this Agreement, an “Excluded Purpose” is any use that is either a Competing Use or a Highly-Available Production Use, or both of them. + +* **1.2.1** A “Competing Use” is making available any on-premises or distributed software product, or any software-as-a-service, platform-as-a-service, infrastructure-as-a-service, or other similar online service, that competes with any products or services that Snowplow or any of its affiliates provides using the Software. + +* **1.2.2** Highly-Available Production Use is any highly-available use, including without limitation any use where multiple instances of any Software component run concurrently to avoid a single point of failure, in a production environment, where production means use on live data. + +**1.3 Conditions.** In consideration of the License, Licensee’s use of the Software is subject to the following conditions: + +* **a.** Licensee must cause any Software modified by Licensee to carry prominent notices stating that Licensee modified the Software. + +* **b.** On each Software copy, Licensee shall reproduce and not remove or alter all Snowplow or third party copyright or other proprietary notices contained in the Software, and Licensee must include the notice below on each copy. + + ``` + This software is made available by Snowplow Analytics, Ltd., + under the terms of the Snowplow Limited Use License Agreement, Version 1.0 + located at https://docs.snowplow.io/limited-use-license-1.0 + BY INSTALLING, DOWNLOADING, ACCESSING, USING OR DISTRIBUTING ANY PORTION + OF THE SOFTWARE, YOU AGREE TO THE TERMS OF SUCH LICENSE AGREEMENT. + ``` + +**1.4 Licensee Modifications.** Licensee may add its own copyright notices to modifications made by Licensee. + +**1.5 No Sublicensing.** The License does not include the right to sublicense the Software, however, each recipient to which Licensee provides the Software may exercise the Licenses so long as such recipient agrees to the terms and conditions of this Agreement. + +## TERM AND TERMINATION + +This Agreement will continue unless and until earlier terminated as set forth herein. If Licensee breaches any of its conditions or obligations under this Agreement, this Agreement will terminate automatically and the License will terminate automatically and permanently. + +## INTELLECTUAL PROPERTY + +As between the parties, Snowplow will retain all right, title, and interest in the Software, and all intellectual property rights therein. Snowplow hereby reserves all rights not expressly granted to Licensee in this Agreement. Snowplow hereby reserves all rights in its trademarks and service marks, and no licenses therein are granted in this Agreement. + +## DISCLAIMER + +SNOWPLOW HEREBY DISCLAIMS ANY AND ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, AND SPECIFICALLY DISCLAIMS ANY WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, WITH RESPECT TO THE SOFTWARE. + +## LIMITATION OF LIABILITY + +SNOWPLOW WILL NOT BE LIABLE FOR ANY DAMAGES OF ANY KIND, INCLUDING BUT NOT LIMITED TO LOST PROFITS OR ANY CONSEQUENTIAL, SPECIAL, INCIDENTAL, INDIRECT, OR DIRECT DAMAGES, HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, ARISING OUT OF THIS AGREEMENT. THE FOREGOING SHALL APPLY TO THE EXTENT PERMITTED BY APPLICABLE LAW. + +## GENERAL + +**6.1 Governing Law.** This Agreement will be governed by and interpreted in accordance with the laws of the state of Delaware, without reference to its conflict of laws principles. If Licensee is located within the United States, all disputes arising out of this Agreement are subject to the exclusive jurisdiction of courts located in Delaware, USA. If Licensee is located outside of the United States, any dispute, controversy or claim arising out of or relating to this Agreement will be referred to and finally determined by arbitration in accordance with the JAMS International Arbitration Rules. The tribunal will consist of one arbitrator. The place of arbitration will be in the State of Delaware, USA. The language to be used in the arbitral proceedings will be English. Judgment upon the award rendered by the arbitrator may be entered in any court having jurisdiction thereof. + +**6.2. Assignment.** Licensee is not authorized to assign its rights under this Agreement to any third party. Snowplow may freely assign its rights under this Agreement to any third party. + +**6.3. Other.** This Agreement is the entire agreement between the parties regarding the subject matter hereof. No amendment or modification of this Agreement will be valid or binding upon the parties unless made in writing and signed by the duly authorized representatives of both parties. In the event that any provision, including without limitation any condition, of this Agreement is held to be unenforceable, this Agreement and all licenses and rights granted hereunder will immediately terminate. Waiver by Snowplow of a breach of any provision of this Agreement or the failure by Snowplow to exercise any right hereunder will not be construed as a waiver of any subsequent breach of that right or as a waiver of any other right. diff --git a/README.md b/README.md index 5a2e5d8..37575a8 100644 --- a/README.md +++ b/README.md @@ -51,6 +51,8 @@ module "bad_1_stream" { module "enrich_kinesis" { source = "snowplow-devops/enrich-kinesis-ec2/aws" + accept_limited_use_license = true + name = "enrich-server" vpc_id = var.vpc_id subnet_ids = var.subnet_ids @@ -100,6 +102,8 @@ EOF module "enrich_kinesis" { source = "snowplow-devops/enrich-kinesis-ec2/aws" + accept_limited_use_license = true + name = "enrich-server" vpc_id = var.vpc_id subnet_ids = var.subnet_ids @@ -148,6 +152,8 @@ EOF module "enrich_kinesis" { source = "snowplow-devops/enrich-kinesis-ec2/aws" + accept_limited_use_license = true + name = "enrich-server" vpc_id = var.vpc_id subnet_ids = var.subnet_ids @@ -245,6 +251,7 @@ module "enrich_kinesis" { | [ssh\_key\_name](#input\_ssh\_key\_name) | The name of the SSH key-pair to attach to all EC2 nodes deployed | `string` | n/a | yes | | [subnet\_ids](#input\_subnet\_ids) | The list of subnets to deploy Enrich across | `list(string)` | n/a | yes | | [vpc\_id](#input\_vpc\_id) | The VPC to deploy Enrich within (must have DNS hostnames enabled) | `string` | n/a | yes | +| [accept\_limited\_use\_license](#input\_accept\_limited\_use\_license) | Acceptance of the SLULA terms (https://docs.snowplow.io/limited-use-license-1.0/) | `bool` | `false` | no | | [amazon\_linux\_2\_ami\_id](#input\_amazon\_linux\_2\_ami\_id) | The AMI ID to use which must be based of of Amazon Linux 2; by default the latest community version is used | `string` | `""` | no | | [assets\_update\_period](#input\_assets\_update\_period) | Period after which enrich assets should be checked for updates (e.g. MaxMind DB) | `string` | `"7 days"` | no | | [associate\_public\_ip\_address](#input\_associate\_public\_ip\_address) | Whether to assign a public ip address to this instance | `bool` | `true` | no | @@ -305,16 +312,9 @@ module "enrich_kinesis" { # Copyright and license -The Terraform AWS Enrich Kinesis on EC2 project is Copyright 2021-2023 Snowplow Analytics Ltd. - -Licensed under the [Apache License, Version 2.0][license] (the "License"); -you may not use this software except in compliance with the License. +Copyright 2021-current Snowplow Analytics Ltd. -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. +Licensed under the [Snowplow Limited Use License Agreement][license]. _(If you are uncertain how it applies to your use case, check our answers to [frequently asked questions][license-faq].)_ [release]: https://github.com/snowplow-devops/terraform-aws-enrich-kinesis-ec2/releases/latest [release-image]: https://img.shields.io/github/v/release/snowplow-devops/terraform-aws-enrich-kinesis-ec2 @@ -322,8 +322,9 @@ limitations under the License. [ci]: https://github.com/snowplow-devops/terraform-aws-enrich-kinesis-ec2/actions?query=workflow%3Aci [ci-image]: https://github.com/snowplow-devops/terraform-aws-enrich-kinesis-ec2/workflows/ci/badge.svg -[license]: https://www.apache.org/licenses/LICENSE-2.0 -[license-image]: https://img.shields.io/badge/license-Apache--2-blue.svg?style=flat +[license]: https://docs.snowplow.io/limited-use-license-1.0/ +[license-image]: https://img.shields.io/badge/license-Snowplow--Limited--Use-blue.svg?style=flat +[license-faq]: https://docs.snowplow.io/docs/contributing/limited-use-license-faq/ [registry]: https://registry.terraform.io/modules/snowplow-devops/enrich-kinesis-ec2/aws/latest [registry-image]: https://img.shields.io/static/v1?label=Terraform&message=Registry&color=7B42BC&logo=terraform diff --git a/main.tf b/main.tf index a87aa55..27d1675 100644 --- a/main.tf +++ b/main.tf @@ -373,6 +373,8 @@ locals { }) user_data = templatefile("${path.module}/templates/user-data.sh.tmpl", { + accept_limited_use_license = var.accept_limited_use_license + config = local.hocon version = local.app_version resolver = "dynamodb:${data.aws_region.current.name}/${aws_dynamodb_table.config.name}/snowplow_resolver" diff --git a/templates/user-data.sh.tmpl b/templates/user-data.sh.tmpl index 6997efb..8e9727f 100644 --- a/templates/user-data.sh.tmpl +++ b/templates/user-data.sh.tmpl @@ -21,6 +21,7 @@ sudo docker run \ %{ endif ~} -v $${CONFIG_DIR}:/snowplow/config \ -e 'JAVA_OPTS=-Dconfig.override_with_env_vars=true ${java_opts}' \ + --env ACCEPT_LIMITED_USE_LICENSE=${accept_limited_use_license} \ -e "CONFIG_FORCE_telemetry_instanceId=$(get_instance_id)" \ snowplow/snowplow-enrich-kinesis:${version} \ --config /snowplow/config/enrich.hocon \ diff --git a/variables.tf b/variables.tf index c62e324..d59751c 100644 --- a/variables.tf +++ b/variables.tf @@ -1,3 +1,14 @@ +variable "accept_limited_use_license" { + description = "Acceptance of the SLULA terms (https://docs.snowplow.io/limited-use-license-1.0/)" + type = bool + default = false + + validation { + condition = var.accept_limited_use_license + error_message = "Please accept the terms of the Snowplow Limited Use License Agreement to proceed." + } +} + variable "name" { description = "A name which will be pre-pended to the resources created" type = string From 6012d2e8e0c59c01e46bec1ab734b2367e3f78e8 Mon Sep 17 00:00:00 2001 From: jbeemster Date: Fri, 2 Feb 2024 17:06:21 +0100 Subject: [PATCH 2/3] Update version to v3.9.0 (closes #36) --- README.md | 5 +++-- main.tf | 6 +++--- templates/config.hocon.tmpl | 1 + templates/user-data.sh.tmpl | 10 +++++----- variables.tf | 8 +++++++- 5 files changed, 19 insertions(+), 11 deletions(-) diff --git a/README.md b/README.md index 37575a8..c22e7b2 100644 --- a/README.md +++ b/README.md @@ -201,7 +201,7 @@ module "enrich_kinesis" { | [instance\_type\_metrics](#module\_instance\_type\_metrics) | snowplow-devops/ec2-instance-type-metrics/aws | 0.1.2 | | [kcl\_autoscaling](#module\_kcl\_autoscaling) | snowplow-devops/dynamodb-autoscaling/aws | 0.2.0 | | [service](#module\_service) | snowplow-devops/service-ec2/aws | 0.2.1 | -| [telemetry](#module\_telemetry) | snowplow-devops/telemetry/snowplow | 0.4.0 | +| [telemetry](#module\_telemetry) | snowplow-devops/telemetry/snowplow | 0.5.0 | ## Resources @@ -253,6 +253,7 @@ module "enrich_kinesis" { | [vpc\_id](#input\_vpc\_id) | The VPC to deploy Enrich within (must have DNS hostnames enabled) | `string` | n/a | yes | | [accept\_limited\_use\_license](#input\_accept\_limited\_use\_license) | Acceptance of the SLULA terms (https://docs.snowplow.io/limited-use-license-1.0/) | `bool` | `false` | no | | [amazon\_linux\_2\_ami\_id](#input\_amazon\_linux\_2\_ami\_id) | The AMI ID to use which must be based of of Amazon Linux 2; by default the latest community version is used | `string` | `""` | no | +| [app\_version](#input\_app\_version) | App version to use. This variable facilitates dev flow, the modules may not work with anything other than the default value. | `string` | `"3.9.0"` | no | | [assets\_update\_period](#input\_assets\_update\_period) | Period after which enrich assets should be checked for updates (e.g. MaxMind DB) | `string` | `"7 days"` | no | | [associate\_public\_ip\_address](#input\_associate\_public\_ip\_address) | Whether to assign a public ip address to this instance | `bool` | `true` | no | | [byte\_limit](#input\_byte\_limit) | The amount of bytes to buffer events before pushing them to Kinesis | `number` | `1000000` | no | @@ -282,7 +283,7 @@ module "enrich_kinesis" { | [iam\_permissions\_boundary](#input\_iam\_permissions\_boundary) | The permissions boundary ARN to set on IAM roles created | `string` | `""` | no | | [initial\_position](#input\_initial\_position) | Where to start processing the input Kinesis Stream from (TRIM\_HORIZON or LATEST) | `string` | `"TRIM_HORIZON"` | no | | [instance\_type](#input\_instance\_type) | The instance type to use | `string` | `"t3a.small"` | no | -| [java\_opts](#input\_java\_opts) | Custom JAVA Options | `string` | `"-Dorg.slf4j.simpleLogger.defaultLogLevel=info -XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=75"` | no | +| [java\_opts](#input\_java\_opts) | Custom JAVA Options | `string` | `"-XX:InitialRAMPercentage=75 -XX:MaxRAMPercentage=75"` | no | | [kcl\_read\_max\_capacity](#input\_kcl\_read\_max\_capacity) | The maximum READ capacity for the KCL DynamoDB table | `number` | `10` | no | | [kcl\_read\_min\_capacity](#input\_kcl\_read\_min\_capacity) | The minimum READ capacity for the KCL DynamoDB table | `number` | `1` | no | | [kcl\_write\_max\_capacity](#input\_kcl\_write\_max\_capacity) | The maximum WRITE capacity for the KCL DynamoDB table | `number` | `10` | no | diff --git a/main.tf b/main.tf index 27d1675..5b2126a 100644 --- a/main.tf +++ b/main.tf @@ -3,7 +3,7 @@ locals { module_version = "0.5.3" app_name = "enrich-kinesis" - app_version = "3.8.0" + app_version = var.app_version local_tags = { Name = var.name @@ -26,7 +26,7 @@ data "aws_caller_identity" "current" {} module "telemetry" { source = "snowplow-devops/telemetry/snowplow" - version = "0.4.0" + version = "0.5.0" count = var.telemetry_enabled ? 1 : 0 @@ -375,7 +375,7 @@ locals { user_data = templatefile("${path.module}/templates/user-data.sh.tmpl", { accept_limited_use_license = var.accept_limited_use_license - config = local.hocon + config_b64 = base64encode(local.hocon) version = local.app_version resolver = "dynamodb:${data.aws_region.current.name}/${aws_dynamodb_table.config.name}/snowplow_resolver" enrichments = "dynamodb:${data.aws_region.current.name}/${aws_dynamodb_table.config.name}/snowplow_enrichment_" diff --git a/templates/config.hocon.tmpl b/templates/config.hocon.tmpl index f39570d..5a0c486 100644 --- a/templates/config.hocon.tmpl +++ b/templates/config.hocon.tmpl @@ -54,6 +54,7 @@ "autoGeneratedId": "${telemetry_auto_gen_id}" "moduleName": "${telemetry_module_name}" "moduleVersion": "${telemetry_module_version}" + "instanceId": $${INSTANCE_ID} } "featureFlags" : { diff --git a/templates/user-data.sh.tmpl b/templates/user-data.sh.tmpl index 8e9727f..55086dd 100644 --- a/templates/user-data.sh.tmpl +++ b/templates/user-data.sh.tmpl @@ -1,8 +1,8 @@ readonly CONFIG_DIR=/opt/snowplow/config sudo mkdir -p $${CONFIG_DIR} -sudo cat << EOF > $${CONFIG_DIR}/enrich.hocon -${config} +sudo base64 --decode << EOF > $${CONFIG_DIR}/enrich.hocon +${config_b64} EOF sudo docker run \ @@ -19,10 +19,10 @@ sudo docker run \ --log-opt max-size=10m \ --log-opt max-file=5 \ %{ endif ~} - -v $${CONFIG_DIR}:/snowplow/config \ - -e 'JAVA_OPTS=-Dconfig.override_with_env_vars=true ${java_opts}' \ + --mount type=bind,source=$${CONFIG_DIR},target=/snowplow/config \ + --env JDK_JAVA_OPTIONS='${java_opts}' \ --env ACCEPT_LIMITED_USE_LICENSE=${accept_limited_use_license} \ - -e "CONFIG_FORCE_telemetry_instanceId=$(get_instance_id)" \ + --env INSTANCE_ID=$(get_instance_id) \ snowplow/snowplow-enrich-kinesis:${version} \ --config /snowplow/config/enrich.hocon \ --iglu-config ${resolver} \ diff --git a/variables.tf b/variables.tf index d59751c..fe70057 100644 --- a/variables.tf +++ b/variables.tf @@ -14,6 +14,12 @@ variable "name" { type = string } +variable "app_version" { + description = "App version to use. This variable facilitates dev flow, the modules may not work with anything other than the default value." + type = string + default = "3.9.0" +} + variable "vpc_id" { description = "The VPC to deploy Enrich within (must have DNS hostnames enabled)" type = string @@ -115,7 +121,7 @@ variable "cloudwatch_logs_retention_days" { variable "java_opts" { description = "Custom JAVA Options" - default = "-Dorg.slf4j.simpleLogger.defaultLogLevel=info -XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=75" + default = "-XX:InitialRAMPercentage=75 -XX:MaxRAMPercentage=75" type = string } From b98902e9d92bddae461ce9b32bfb9640052c888d Mon Sep 17 00:00:00 2001 From: jbeemster Date: Fri, 2 Feb 2024 17:06:56 +0100 Subject: [PATCH 3/3] Prepared for release --- CHANGELOG | 5 +++++ main.tf | 2 +- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/CHANGELOG b/CHANGELOG index b4aaffa..5ed57ce 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,3 +1,8 @@ +Version 0.6.0 (2024-02-02) +-------------------------- +Update LICENSE to SLULA (#35) +Update version to v3.9.0 (#36) + Version 0.5.3 (2024-01-17) -------------------------- Bump service module to v0.2.1 (#34) diff --git a/main.tf b/main.tf index 5b2126a..94e8691 100644 --- a/main.tf +++ b/main.tf @@ -1,6 +1,6 @@ locals { module_name = "enrich-kinesis-ec2" - module_version = "0.5.3" + module_version = "0.6.0" app_name = "enrich-kinesis" app_version = var.app_version