2022-07-05 10:07:15 -04:00
<!--
Styleguide for this document:
- Sentences should end with a period.
- This is the keepachangelog style, whereas the Microsoft Style Guide we use for other docs omits periods for short list items.
- Omit the verb if possible.
- "Early boot logging ..." instead of "Add early boot logging ...".
- If you need a verb, it should usually be imperative mood (Add instead of Added).
- Items should start with a capital letter.
-->
2022-05-27 10:53:16 -04:00
# Changelog
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
All notable changes to Constellation will be documented in this file.
The format is based on [Keep a Changelog ](https://keepachangelog.com/en/1.0.0/ ),
and this project adheres to [Semantic Versioning ](https://semver.org/spec/v2.0.0.html ).
2022-08-12 09:59:45 -04:00
2022-05-27 10:53:16 -04:00
## [Unreleased]
2022-08-12 09:59:45 -04:00
2022-08-02 12:49:55 -04:00
### Added
2022-08-09 03:13:05 -04:00
2022-08-31 06:27:26 -04:00
- Support Linux arm64 and macOS (arm64 and amd64) for Constellation CLI.
2022-08-16 12:48:33 -04:00
- Create multiple load balancers to enable load balacing TCP traffic for different backend services. All load balancers currently share the same public IP address.
- Improve rollback on GCP resource termination. You can now terminate multiple times.
- Implement SSH peer to peer distribution between debugd nodes.
2022-08-23 11:49:55 -04:00
- GCP service account can now be managed manually.
2022-08-29 08:43:01 -04:00
- Azure resource group can now be managed manually and can be resused after termination.
- Azure Active Directory client credentials can now be managed manually.
- Resources on Azure are now tagged with the UID of the constellation.
2022-08-26 11:34:46 -04:00
- CoreOS images are publicly available for Azure.
2022-08-29 03:50:40 -04:00
- GCP: Support for higher end N2D standard (128 & 224 vCPUs), *high-mem* and *high-cpu* VMs
2022-08-29 10:49:44 -04:00
- Add `constellation upgrade` to update node images in Constellation.
2022-08-31 09:37:07 -04:00
- Add cilium v1.12.1 with strict mode v2
2022-08-23 07:43:20 -04:00
2022-08-19 08:58:07 -04:00
### Changed
2022-08-16 12:48:33 -04:00
<!-- For changes in existing functionality. -->
- Use IP from Constellation ID file in init and verify instead of IPs from state file.
2022-08-29 08:43:01 -04:00
- Terminate now deletes all resources found within the given resource group.
2022-08-16 12:48:33 -04:00
- Change cdbg to use load balancer for deploy.
2022-08-31 06:25:27 -04:00
- cdbg now uses the Constellation config directly and does not require any extra config
2022-08-19 06:26:29 -04:00
- Azure CVMs are attested using SNP attestation
2022-08-31 09:37:07 -04:00
- Replaced kube-proxy with cilium
2022-08-31 11:35:33 -04:00
- VM instance types are now defined in the config, not via a CLI argument
2022-08-19 08:58:07 -04:00
### Deprecated
<!-- For soon - to - be removed features. -->
### Removed
<!-- For now removed features. -->
2022-08-29 08:43:01 -04:00
- Azure Trusted Launch instance types with 2 CPUs (SMT disabled due to Retbleed (CVE-2022-29900)).
2022-08-31 06:25:27 -04:00
- cdbg: Custom systemd service deployment
2022-08-29 08:43:01 -04:00
2022-08-19 08:58:07 -04:00
### Fixed
### Security
<!-- In case of vulnerabilities. -->
### Internal
## [1.5.0] - 2022-08-19
### Added
2022-08-09 03:13:05 -04:00
- Kubernetes operator for Constellation nodes with ability to update node images.
2022-08-16 09:53:54 -04:00
- CoreOS images are publicly available for GCP.
- Cilium strict pod2pod encryption.
2022-08-12 09:59:45 -04:00
- Add a configurable list of enforced measurements to the config. If an expected measurement can not be verified during attestation, but it is not in the list of enforced measurements, only a warning is logged.
2022-08-19 08:58:07 -04:00
- License check during init
2022-08-12 09:59:45 -04:00
2022-08-02 12:49:55 -04:00
### Changed
2022-08-19 08:35:36 -04:00
- Use Azure CVMs instead of Trusted Launch VMs.
2022-08-19 08:58:07 -04:00
- Parallel resource creation on Azure.
2022-08-19 08:35:36 -04:00
2022-08-02 12:49:55 -04:00
### Fixed
2022-08-19 07:28:16 -04:00
- Fix timeout issue during cilium installation.
2022-08-19 08:35:36 -04:00
2022-08-02 12:49:55 -04:00
### Internal
2022-08-12 09:59:45 -04:00
2022-08-09 04:02:15 -04:00
- Run e2e tests on all supported versions.
2022-08-09 09:29:39 -04:00
- Run e2e tests on latest debug images, instead of release image.
2022-08-19 08:58:07 -04:00
- Upgrade Azure SDK
2022-08-02 12:49:55 -04:00
## [1.4.0] - 2022-08-02
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
### Added
2022-06-02 04:57:48 -04:00
2022-08-02 12:49:55 -04:00
- Publish measurements for each released coreos-image.
- `constellation config fetch-measurements` to download and verify measurements, and writing them into the config file.
- Configurable Kubernetes version through an entry in `constellation-config.yaml` .
- Kubernetes version 1.24 support.
- Kubernetes version 1.22 support.
- Log disk UUID to cloud logging for recovery.
2022-08-02 06:35:23 -04:00
- Configurable disk type for Azure and GCP.
2022-08-02 12:49:55 -04:00
- Create Kubernetes CA signed kubelet certificates on activation.
- Salt key derivation.
- Integrity protection of state disks.
2022-07-26 11:08:57 -04:00
2022-06-02 04:57:48 -04:00
### Changed
2022-07-05 10:07:15 -04:00
2022-08-02 12:49:55 -04:00
- Nodes add themselves to the cluster after `constellation init` is done. Previously, nodes were asked to join the cluster by the bootstrapper.
- Owner ID and Unique ID are merged into a single value: Cluster ID.
- Streamline logging to only use one logging library, instead of multiple.
- Replace dependency on github.com/willdonnelly/passwd with own implementation.
2022-06-02 04:57:48 -04:00
### Removed
2022-08-02 12:49:55 -04:00
- User facing WireGuard VPN.
2022-07-05 08:14:11 -04:00
2022-06-02 04:57:48 -04:00
### Fixed
2022-07-29 03:52:47 -04:00
2022-08-02 12:49:55 -04:00
- Correctly wait for `bootstrapper` to come online during `constellation init` .
2022-06-02 04:57:48 -04:00
2022-07-11 09:19:56 -04:00
## [1.3.1] - 2022-07-11
### Changed
2022-07-29 03:52:47 -04:00
2022-07-11 09:19:56 -04:00
- Update default CoreOS image to latest version (1657199013).
### Fixed
2022-07-29 03:52:47 -04:00
2022-07-11 09:19:56 -04:00
- Add load balancer path to Azure deployment so that PCR values can be read.
- Show correct version number in `constellation version` .
### Removed
2022-07-29 03:52:47 -04:00
2022-07-11 09:19:56 -04:00
- Support for Azure `Standard_*_v3` types.
2022-07-05 10:07:15 -04:00
## [1.3.0] - 2022-07-05
2022-07-29 03:52:47 -04:00
2022-06-02 05:07:05 -04:00
### Added
2022-07-29 03:52:47 -04:00
2022-09-01 03:27:25 -04:00
- Early boot logging for GCP and Azure. [[Docs]](https://docs.edgeless.systems/constellation/workflows/troubleshooting#cloud-logging)
- `constellation-access-manager` allows users to manage SSH users over a ConfigMap. Enables persistent and dynamic management of SSH users on multiple nodes, even after a reboot. [[Docs]](https://docs.edgeless.systems/constellation/workflows/ssh)
- GCP-native Kubernetes load balancing. [[Docs]](https://docs.edgeless.systems/constellation/architecture/networking)
- `constellation version` prints more information to aid in troubleshooting. [[Docs]](https://docs.edgeless.systems/constellation/reference/cli#constellation-version)
2022-07-05 10:07:15 -04:00
- Standard logging for all services and CLI, allows users to control output in a consistent manner.
- `constellation-id.json` in Constellation workspace now holds cluster IDs, to reduce required arguments in Constellation commands, e.g., `constellation verify` .
2022-06-02 05:07:05 -04:00
### Changed
2022-07-29 03:52:47 -04:00
2022-07-05 10:07:15 -04:00
- New `constellation-activation-service` offloads Kubernetes node activation from monolithic Coordinator to Kubernetes native micro-service. [[ReadMe]](https://github.com/edgelesssys/constellation/blob/main/activation/README.md)
- Improve user-friendliness of error messages in Constellation CLI.
- Move verification from extracting attestation statements out of aTLS handshake to a dedicated `verify-service` in Kubernetes with gRPC and HTTP endpoints.
2022-06-02 05:07:05 -04:00
### Security
2022-07-29 03:52:47 -04:00
2022-07-05 10:07:15 -04:00
- GCP WireGuard encryption via cilium.
2022-06-02 05:07:05 -04:00
### Internal
2022-07-29 03:52:47 -04:00
2022-07-05 10:07:15 -04:00
- Refactore folder structure of repository to better reflect `internal` implementation and public API.
- Extend `goleak` checks to all tests.
## [1.2.0] - 2022-06-02
2022-07-29 03:52:47 -04:00
2022-07-05 10:07:15 -04:00
### Changed
2022-07-29 03:52:47 -04:00
2022-07-05 10:07:15 -04:00
- Replace flannel CNI with Cilium.
2022-06-02 05:07:05 -04:00
2022-06-02 04:57:48 -04:00
## [1.1.0] - 2022-06-02
2022-07-29 03:52:47 -04:00
2022-06-02 04:57:48 -04:00
### Added
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- CLI
- Command `constellation recover` to re-initialize a completely stopped cluster.
- Command `constellation config generate` to generate a default configuration file for a specific cloud provider.
- CSI
- Option to enable dm-integrity in a StorageClass.
- Support volume expansion.
- Support volume snapshots.
2022-06-02 04:57:48 -04:00
- KMS
- Deploy Key Management Service (KMS) in Constellation clusters to handle key derivation.
2022-05-27 10:53:16 -04:00
- Option to add SSH users on init.
### Changed
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- CLI UX
- `constellation create` now requires a configuration file. The usual workflow is to run `constellation config generate` first.
- Consistent command format with at most one argument and named flags otherwise.
- Display usage when invalid arguments are passed.
- Add list of instance types to command help.
- Wording tweaks.
- CLI config
- Rename dev-config to config.
- Change format to YAML.
- Make it self-documenting.
- Validation.
- Rename *PCRs* to *Measurements* .
### Removed
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- Support for non-CVMs on GCP.
### Fixed
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- Pin Kubernetes version deployed by `kubeadm init` .
### Security
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- Replace single, never expiring Kubernetes join token with expiring unique tokens.
- Apply CIS benchmark for kubeadm clusterconf and kubelet conf.
- Enable Kubernetes audit log.
### Internal
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
- Create GCP images in `constellation-images` project so that they can be shared with customers.
- Add customer onboarding docs.
- Add E2E test as Github Action.
- Improvements to local QEMU testing.
- Preparations for mutual ATLS.
## [1.0.0] - 2022-04-28
2022-07-29 03:52:47 -04:00
2022-05-27 10:53:16 -04:00
Initial release of Constellation. With underlying WireGuard and Kubernetes compliant.
2022-08-19 08:58:07 -04:00
[Unreleased]: https://github.com/edgelesssys/constellation/compare/v1.5.0...HEAD
[1.5.0]: https://github.com/edgelesssys/constellation/compare/v1.4.0...v1.5.0
2022-08-02 12:49:55 -04:00
[1.4.0]: https://github.com/edgelesssys/constellation/compare/v1.3.1...v1.4.0
2022-07-11 09:19:56 -04:00
[1.3.1]: https://github.com/edgelesssys/constellation/compare/v1.3.0...v1.3.1
2022-07-05 10:07:15 -04:00
[1.3.0]: https://github.com/edgelesssys/constellation/compare/v1.2.0...v1.3.0
[1.2.0]: https://github.com/edgelesssys/constellation/compare/v1.1.0...v1.2.0
[1.1.0]: https://github.com/edgelesssys/constellation/compare/v1.0.0...v1.1.0
2022-05-27 10:53:16 -04:00
[1.0.0]: https://github.com/edgelesssys/constellation/releases/tag/v1.0.0