History

0.11.0 (2021-01-14)

First release of 2021 focusing on some new features / extension of existing features, as well on improving stability.

New features

885e89e - DB Secrets exposable to services (#356) (John Preston) b723cc7 - Allow to override subnets to use for resources deployed inside VPC (#353) (John Preston) 0c6c86c - Create PrefixList for VPC and suibnets when creating a new VPC (#352) (John Preston) 4405fef - Support for ElasticCache Cluster via x-elasticache (#350) (John Preston) 59ceae0 - Added support for CodeGuru Profiling Group (#323) (John Preston) 97529fa - x-docdb support for DBClusterParameterGroup (#349) (John Preston) a8888b6 - Extending ecs-plugin x-fields support (#336) (John Preston)

Improvements

faed0d3 - Align to CamelCase for x-scaling and x-network settings (#347) (John Preston) 249ba18 - Moved defauls into properties dicts. Added more docstrings for clarity (#345) (John Preston) 97345c7 - Pyup/updates (#329) (John Preston) 774640b - Create pyup.io config file (#327) (pyup.io bot)

Fixes

8d14ac0 - Fix for use_cloudmap (#346) (John Preston) aa1ba40 - Fixed properties update (#344) (John Preston) d2cd544 - Fixing VPC related settings (#341) (John Preston)

0.10.0 (2020-12-13)

New features

  • 976e5bb Support for env_file (#318)

  • a432763 Import simple SAM IAM policies templates. (#316)

  • db2c8fe Support for service-to-service explicit ingress (#300)

  • fe1e0af Added to support DB Snapshot for new DB creation (#297)

  • 73cdf9a x-vpc - Support for VPC FlowLogs (#296)

  • b9f1ec8 Scaling rules for Lookup queues (#293)

  • 54faa50 Feature x-dns::Records to add Public DNS Records pointing to elbv2 (#289)

  • d5a97a1 Adding support for kinesis streams (#287)

Improvements

  • 1be3b99 Improved secrets JsonKeys based on suggestions (#322)

  • 6302bc6 x-rds:: Refactor Properties/MacroParameters/Settings (#309)

Fixes

  • 191d420 No interpolate ${AWS::PseudoParameters} (#324)

  • de87457 Bug fixes for RDS/DocDB and ECS containers (#305)

  • 4220d7d TMP solution pending AWS official XRay publish (#304)

  • 2c1fcfc Fix/duplicate secrets keys (#303)

  • 4befc25 Fixed backward logic (#301)

Other updates and corrections

  • 31d7bcc Added kinesis docs (#313)

  • 997f0d9 Added back exports but not using in ComposeX. For cross-stacks usage (#310)

  • cb0be55 Linted up code (#307)

  • 5e559f0 Prefixing the log group with the root stack name for uniqueness (#295)

  • c81f443 Refactored to single function recursively evaluating properties (#291)

  • 16a5d39 Code linting (#285)

0.9.0 (2020-11-26)

New features

  • cabd793 - Support for networks: and mapping to additional subnets. (#282)

  • ba4ed5c - ECS Scheduled tasks support (#280)

  • 82e2086 - Defaulting to encrypted for RDS (#276)

  • a516a09 - Added support for service level x-aws keys from ecs-plugin (#273)

  • 5e1ab08 - Improved logging settings (#265)

  • 96ad398 - x-secrets::Lookup (#256)

  • dfb249c - Lookup for ACM working (#254)

  • ea6e05c - Feature x-docdb (#252)

  • 0a4d258 - Refactor services to root stack (#248)

  • 49a9d31 - ARN of TGT Group always passed to service stack (#245)

  • eafcd38 - Updated documentation (#236)

  • aa4c96b - Feature x-elbv2 with x-acm support and validation via x-dns (#228)

  • fb0bc4a - Allowing RoleArn in x-rds Lookup (#233)

  • 22feb56 - Lookup via resources tag api for VPC resources (#231)

  • be536c1 - Cross-Cccount assume role generally and locally for lookup (#229)

  • 32075f2 - Allow for custom cooldown for steps (#221)

  • ca89836 - Upgrading troposphere==2.6.3 (#216)

  • 3a1b0c8 - Linting DynDB features and use-case files (#213)

  • 67cc67e - Feature x-s3 (#196)

  • 230a9d3 - Lookup RDS DB/Clusters and secrets (#211)

Fixes

  • fc55f4b - Patched version of 0.8.9 with previews for 0.9.0 (#275)

  • 1dc4113 - Replaced LOG.warn with LOG.warning (#271)

  • 42c7027 - Docs improvements (#278)

  • 78bef91 - Clarified Ingress syntax (#261)

  • af31f33 - Fixed a number of small issues (#259)

  • 02da4e1 - Hotfix services attributes (#243)

  • fb7265a - During PyCharm refactor, error change occured (#238)

  • c46c208 - Fixing import export string (#224)

  • 7669799 - Removing missed print (#217)

  • 4171044 - Fixing condition when QueueName property is set (#210)

  • 0ced643 - Patched SQS based scaling rule and alarm (#202)

Syntax changes from previous version

  • 86d2141 - Refactor/services xconfig keys (#269)

  • 1cfa6b7 - Refactor AppMesh properties keys (#262)

  • d753473 - Refactor to classes for XResources and Compose resources (#219)

Documentation theme changed to Read The Docs and tuned some colors.

0.7.0 (2020-08-12)

New features:

Various bug fixes and some small features to help making plug-and-play easier. Introduction to Use which should allow for resources reference outside of your account without cross-account lookup.

0.6.0 (2020-08-03)

New features: * Docker-compose multi-files (override support)

The new CLI uses positional arguments matching a specific command which drives what’s executed onwards. Trying to re-implement features as close to the docker-compose CLI as possible.

  • config allows to get the YAML file render of the docker-compose files put together.

  • render will put all input files together and generate the CFN templates accordingly.

  • up will deploy do the same as render, and deploy to AWS CFN.

0.5.3 (2020-07-30)

A lot of minor bug fixes and removing CLI commands to the benefit of better implementation via the compose file.

0.5.2 (2020-07-30)

New features:

The support for KMS will be extended to use the CMK for RDS/SQS/SNS and any resource that can use KMS for encryption at rest.

Hint

Mind, this might occur a few extra costs.

0.5.1 (2020-07-28)

Small bug patches and code refactoring. SQS now into a single stack unless there are more than 30 queues.

0.5.0 (2020-07-27)

New features

0.4.0 (2020-07-20)

To help with code quality and support, I subscribed to the following services:

0.3.0 (2020-06-21)

Refactored the way the services, task definitions and containers are put together, in order to support multiple new features:

The support for Docker compose compute settings allows to add up all the CPU / RAM of your service(s) and identify the closest Fargate CPU/RAM configuration for the Task Definition (the respective CPU/RAM of each task is unchanged).

The docker-compose file is now more strictly close to the definition set in Docker Compose, with regards to attributes and their expected types.

Note

In order to respect more closely the docker-compose definition, the key previously used configs now is x-configs

0.2.3 (2020-04-16)

Refactored the ecs part into a class and reworked the configuration settings to allow for easier integration. Documentation has been updated to reflect the changes in the structure of the configs section.

New features

  • Enable AWS X-Ray (#56)

    Enabling X-Ray will allow developer to get APM metrics and visualize the application interaction with other services.

  • No-upload (#64)

    This allows to store the templates locally only.

    Note

    The templates are still validated from their body

  • IAM Boundary for the IAM roles (#55)

    Permissions boundary are an IAM feature that allows to set boundaries which superseed other permissions associated to the entity. It is often the put as a condition for users creating roles to assign a specific Permission Boundary policy to the roles created.

0.2.2 (2020-04-10)

Refactor of the ECS service template into a single class (still got to be reworked). Refactored the ECS Services into a master class which ingests the CLI kwargs directly.

Reworked and reorganized documentation to help with readability

0.2.1 (2020-05-03)

Code refactored to allow a better way to go over each template and stack so everything is treated in memory before being put into a file and uploaded into S3.

  • Issues closed
    • Docs update and first go at IAM perms (#22)

    • Refactor of XModules logic onto ECS services (#39)

    • Templates & Stacks refactor (#38)

    • Update issue templates for easy PRs and Bug reports

    • Added make conform to run black against the code to standardize syntax (#26)

    • Allow to specify directory to write all the templates to in addition to S3. (#27)

    • Reformatted with black (#25)

    • Expand TagsSpecifications with x-tags (#24)

    • Bug fix for root template and Cluster reference (#20)

Documentation structure and content updated to help navigate through modules in an easier way. Documented syntax reference for each module

New features

  • #6 - Implement x-rds. Allows to create RDS databases with very little properties needed
    • Creates Aurora cluster and DB Instance

    • Creates the DB Parameter Group by importing default settings.

    • Creates a common subnet group for all DBs to run into (goes to Storage subnets when using –create-vpc).

    • Creates DB username and password in AWS SecretsManager

    • Applies IAM permissions to ECS Execution Role to get access to the secret

    • Applies ECS Container Secrets to the containers to provide them with the secret values through Environment variables.

0.1.3 (2020-04-13)

A patch release with a lot of little features added driven by the writing up of the blog to make it easier to have in a CICD pipeline.

See overall progress on GH Project

Issues closed

0.1.2 (2020-04-04)

Patch release aiming to improve the CLI and integration of the Compute layer so that the compute resources creation in EC2 are standalone and can be created separately if one so wished to reuse.

Issues closed

Issue related to the fix.

PR related to the fix.

0.1.1 (2020-04-02)

Added tags definition from Docker ComposeX with the x-tags which allows to add tags to all resources that support tagging from AWS CFN

x-tags:
  - name: TagA
    value: SomeValue
  - name: CostcCentre
    value: IamNotPayingForThis
  - name: Some:Special:Key
    value: A long weird value

or alternatively in an object/dict format

x-tags:
  TagA: ValueA
  TagB: ValueB

0.1.0 (2020-03-24)

  • First release on PyPI.
    • Working VPC + Cluster + Services

    • Working expansion of existing Cluster with new VPC

    • Working expansion of existing VPC and Cluster with new services

    • IAM working to allow services access to SQS queues

    • SQS Queues functional with DLQ

    • Works on Python 3.6, 3.7, 3.8

    • Working start of build integration in CodeBuild for automated testing