Skip to content
nadeempat edited this page Jan 9, 2024 · 59 revisions

Blueprints in Amazon CodeCatalyst

Blueprints are used to generate (and regenerate) projects in Amazon CodeCatalyst. A blueprint takes user input options, combines the input options with the blueprint's logic to output a project bundle, which Codecatalyst uses to make (or modify) resources in a project. Blueprints are themselves code which write code.

Blueprints can generate code in any language and create almost any CodeCatalyst resource. They often generate common files, configurations, and workflows for a project type. Blueprints can, for example, set up a web application project that contains a CDK stack and CodeCatalyst workflows that auto-deploys into an aws account.

The Amazon Codecatalyst team publishes several official blueprints, but Space administrators or Power users in CodeCatalyst can make their own using the blueprint builder and blueprint components. As a blueprint author, you can add your custom blueprints to their space’s blueprints catalog in CodeCatalyst. Space members can then use the blueprints to create new CodeCatalyst projects or apply them to existing projects. For more information, Working with custom blueprints in CodeCatalyst.

Working with blueprints

Traditionally, teams use templates to get started with the necessary tooling and requirements. However, projects created from traditional templates become outdated as soon as the template standards change, requiring manual updates to all prior projects to adopt the latest changes. In practice, this makes templates ineffective for defining, enforcing, or evolving best practices.

Blueprints make standards a living, evolving concept rather than a static or point-in-time reference. Blueprints are living documents that can automatically and securely update all projects built from them as standards change over time. This means you can define and iterate on best practices in your blueprint, and then safely push those updates to all associated projects, creating multiple pull requests along the way. For more information, see Working with lifecycle management as a blueprint author and Resynthesis.

Creating a custom blueprint

As a blueprint author, you might have a specific type of project in mind that you would like their blueprint to generate. In CodeCatalyst, you can create a new CodeCatalyst project that contains all the starter code for a new blueprint. You must be a Space administrator or a Power user. For more information, see Getting started with custom blueprints.

Developing a custom blueprint

The typical development flow for a custom blueprint is progressively making updates to the blueprint.ts class, running yarn blueprint:synth to see the output under synth/ and then doing that again as the output gets closer to the project blueprint authors have in mind.

You can test their blueprint locally using the following: yarn blueprint: synth. A blueprint is generated in the synth/synth.[options-name]/proposed-bundle/ folder. For more information, see Synthesis.

If you're updating your custom blueprint, instead, run the following command to resynthesize your project: yarn blueprint: resynth. A blueprint is generated in the synth/synth.[options-name]/proposed-bundle/ folder. For more information, see Resynthesis.

In the process of development, you can use components to quickly build blueprints. You might also want to ask users for input. The blueprint wizard is able to dynamically generate itself form the blueprint’s Options interface found at the top of the blueprint.ts file. For example, adding a string field to the interface prompts the user for a text input filed, or adding an enum field creates a radio selection. You can utilize the user input to change how and what code should be generated. Corresponding entries must be added to the defaults.json file. For more information, see Working with a wizard, Environment components, Region components, Repository and source code components, Workflow components, and Workspace components.

Publishing a custom blueprint

After creating and developing a custom blueprint, you can fully test their blueprint end to end in CodeCatalyst by publishing a preview version. This allows you to view the blueprint as a user before adding the non-preview version to the catalog. The preview version allows you to publish without taking up an actual version. For more information, see Viewing and publishing a preview version of a custom blueprint.

Custom blueprint concepts

Preview bundles

Custom blueprints write out preview bundles as a result of a successful synthesis. A bundle includes folders to help blueprint authors determine where resources should be located. For example, under src/, there can be data that gets deployed as source code, or YAML representations of environments can be located under environments. As a blueprint author, you don’t need to know the format if they are using blueprint components — each component writes to the appropriate location in the bundle. The bundle is used by the CodeCatalyst deployment system to create and seed various CodeCatalyst resources from the blueprint. The bundle is also used by the preview flow to preview the generated code. For more information, see Resynthesis and Three-way merge.

Synthesis

Synthesis is the process of generating a CodeCatalyst project bundle that represents the source code, configuration, and resources in a project. The bundle is then used by CodeCatalyst deployment API operations to deploy into a project. The process can be run locally while developing your custom blueprint to emulate project creation without having to create a project in CodeCatalyst. The following commands can be used to perform synthesis:

yarn blueprint:synth             # fast mode
yarn blueprint:synth --cache     # wizard emulation mode

The blueprint starts itself by calling the main blueprint.ts class with that option merged on defaults.json. A new project bundle is generated under the synth/synth.[options-name]/proposed-bundle/ folder. The output includes the project bundle that a custom blueprint generates, given the options you set, including the partial options that you may have configured.

Resnythesis

Resynthesis is the process of regenerating a blueprint with different blueprint options or blueprint versions of existing projects. As a blueprint author, you can define custom merge strategies in the custom blueprint code. You can also define ownership boundaries in an .ownership-file to specify in which parts of the codebase a blueprint is permitted to be updated. While the custom blueprint can propose updates to the .ownership-file, project developers using the custom blueprint can determine ownership boundaries for their projects. You can run resynthesis locally, and test and update before publishing your custom blueprint. Use the following commands to perform resynthesis:

yarn blueprint:resynth             # fast mode
yarn blueprint:resynth --cache     # wizard emulation mode

The blueprint starts itself by calling the main blueprint.ts class with that option merged on defaults.json. A new project bundle is generated under the synth/resynth.[options-name]/ folder. The output includes the project bundle that a custom blueprint generates, given the options you set, including the partial options that you may have configured.

The following contents are created after the synthesis and resynthesis processes:

  • proposed-bundle - The output of synthesis when it is run with new options for the target blueprint version.
  • existing-bundle - A mock of your existing project. If there's nothing in this folder, it's generated with the same output as the proposed-bundle.
  • ancestor-bundle - A mock of what your blueprint would generate when run with either a prior version, prior options, or a combination. If there's nothing in this folder, it's generated with the same output as the proposed-bundle.
  • resolved-bundle - The bundle is always regenerated and defaults to a three-way merge between the proposed-bundle, existing-bundle, and the ancestor-bundle. This bundle provides an emulation of what a resynthesis would output locally.

To learn more about blueprint output bundles, see Three-way merging.

Projen

Projen is an open-source tool that custom blueprints use to keep themselves updated and consistent. Blueprints come as Projen packages because this framework provides you with the ability to build, bundle, and publish projects, and you can use the interface to manage a project's configurations and settings.

You can use Projen to update blueprints at scale, even after they're created. The Projen tool is the underlying technology behind the blueprint synthesis that generates a project bundle. Projen owns the configuration for a project, and it shouldn't impact you as a blueprint author. You can run yarn projen to regenerate the configuration of your project after adding dependencies, or you can change options in the projenrc.ts file. Projen is also the underlying generation tool for custom blueprints to synthesize a project. For more information, see the projen GitHub page. To learn more about working with Projen, see the Projen documentation and How to simplify project setup with Projen.