Releases: KusionStack/kusion
v0.14.0
Features
Kusion Server
In this version, we are thrilled to introduce the release of Kusion Server, which is designed to provide a centralized and simplified application delivery and resource management, as well as an efficient collaboration paradigm for application developers and platform engineers. Here are some core features of Kusion Server that may transform and empower your application delivery:
- End-to-end LifeCycle Management: Users can take control of the entire application lifecycle with a codified approach.
- Protocol-Driven Collaboration: Kusion enables seamless collaboration across the organization with a separation of concerns.
- Application Resource Graphs: Kusion provides a visualized resource topology to help users understand how application resources interact.
Enhanced Resource Management
In this version, we enhance the resource management with new CLI's commands and Server's APIs:
- Resource Show: We introduced a new
kusion resource show
command to display resource details for better observability. @hoangndst - Resource Graph: We added a new
kusion resource graph
command and related API to provide a graphical representation of all the resources in target project and workspace. @Yangyang96
Enhanced Run Management
We improved the usability and flexibility in managing Kusion Server's runs, which includes Generate
, Preview
, Apply
, and Destroy
, with:
- Async Runs: We added support for asynchronous run operations to improve performance and reduce blocking. @ffforest
- Run Type Parsing: We improved handling of run types and statuses in various scenarios. @ffforest
- Watch Runs: We added support for watching run progress directly via APIs. @ffforest
Backend and Workspace Enhancement
- We added support for using Google Cloud Storage as a backend for storing and managing resources. @ffforest
- Server now supports fetching and configuring workspace modules, enabling more flexible workflows. @liu-hm19
Developer Portal
- We introduced a developer portal to provide a central hub for project information and resources. @hai-tian
Kusion Module Update
- We updated the logger and related SDKs for Kusion Modules in kusion-module-framework, which now supports trace and rotation with separate file storage. @gshilei @liu-hm19
Bug Fixes
- Resolved the problems with resource dependency changing status without being updated. @riven-blade
- Address empty resource names and types for HashiCorp Terraform resources. @ffforest
- Fixed issues with generated Swagger API responses and documentations. @Yangyang96
New contributors
- @gshilei made their first contribution in #1332
- @riven-blade made their first contribution in #1363
- @hai-tian made their first contribution in #1351
Docker images
kusionstack/kusion:v0.14.0
v0.14.0-rc.1
What's Changed
- feat: add resource show command by @hoangndst in #1299
- docs: update README.md to include OpenSSF Best Practice Badge by @ffforest in #1301
- chore(deps): bump github.com/golang-jwt/jwt/v4 from 4.5.0 to 4.5.1 by @dependabot in #1308
- feat: add kusion module apis for server by @liu-hm19 in #1310
- feat: support async runs by @ffforest in #1312
- fix: table name case sensitivity in join and pattern statement by @liu-hm19 in #1314
- feat: add kusion resource graph api for server by @Yangyang96 in #1323
- fix: able to parse run type and status in in any cases by @ffforest in #1315
- feat: server supports getting workspace modules by @liu-hm19 in #1313
- feat: add workspace config apis for kusion server by @liu-hm19 in #1311
- chore: optimize runs api by @ffforest in #1324
- feat: add trace for module and split module logs by @gshilei in #1332
- refactor: appconfig and module generators by @liu-hm19 in #1333
- feat: enable force unlock and optimize failure handling in execute api by @ffforest in #1339
- test: wrap workspace unit tests into a suite by @liu-hm19 in #1346
- feat: support watch in runs by @ffforest in #1343
- Feat add resource ID validation and resource URN by @ffforest in #1348
- feat: add filters for list sources, modules and runs APIs by @Yangyang96 in #1349
- fix: import v1 package for swagger doc generation by @Yangyang96 in #1350
- fix: swagger doc generated response by @Yangyang96 in #1352
- feat: add kusion mod login and pull sub-command by @liu-hm19 in #1345
- feat: support google cloud storage as backend by @ffforest in #1356
- feat: add pagination for server entities by @liu-hm19 in #1347
- fix: modules and runs api by @Yangyang96 in #1364
- fix: the problem of dependency change status not being updated by @riven-blade in #1363
- chore: clean swagger API queries by @Yangyang96 in #1366
- fix: kusion server handler swagger apis by @liu-hm19 in #1365
- fix: removal env patcher by @liu-hm19 in #1368
- fix: missing default source name by @Yangyang96 in #1369
- chore: add API POST request validation by @Yangyang96 in #1371
- chore: mask backend sensitive data by @Yangyang96 in #1373
- feat: support patcher removal for label and annotation by @liu-hm19 in #1374
- fix: workspace update and delete API by @Yangyang96 in #1375
- chore: support fuzzy match project name by @Yangyang96 in #1376
- fix: use default foreign key by @Yangyang96 in #1377
- fix: correct naming by @Yangyang96 in #1379
- fix: npe when default backend is not set by @ffforest in #1378
- feat: add developer portal by @hai-tian in #1351
- feat: add sort options in runs and projects list api by @ffforest in #1381
- feat: add stack delete/action by @hai-tian in #1383
- chore: update dockerfile and bump kpm pkg version by @liu-hm19 in #1384
New Contributors
- @gshilei made their first contribution in #1332
- @riven-blade made their first contribution in #1363
- @hai-tian made their first contribution in #1351
Full Changelog: v0.13.0...v0.14.0-rc.1
v0.13.0
Features
Kusion Release Comand
In this version, we add a new command kusion release
to help users observe and operate the Kusion Release
files. It contains the following three sub-commands:
kusion release list
lists all theRelease
files of the currentProject
in the specifiedWorkspace
. @ekjotsinghmakhijakusion release show
shows the details of aRelease
file of the current or the specifiedProject
. @hoangndstkusion release unlock
unlocks the latestRelease
file of the currentProject
in the specifiedWorkspace
. @liu-hm19
Kusion Resource Command
In this version, we add a new command kusion resource
to help users observe the information of the Kusion Resources
within a specified Project
and Workspace
. It contains the following sub-command:
kusion resource graph
displays a graph of all the resource information of the targetProject
andWorkspace
. @Yangyang96
Kusion Project Sub-command
In this version, we add a new sub-command kusion project list
for kusion project
to help users list all the applied Projects
in the target Backend
and Workspace
. @Yangyang96
KCL-based Customized Health Check
In the previous versions, Kusion watches the reconciliation status of some specific Kubernetes resources while applying, and now in v0.13.0
we support KCL-based health check for users to customize the reconciliation conditions for any Kubernetes resources. @Yangyang96
Viettel Cloud Secrets Manager
In the previous versions, Kusion supports AWS
and Alicloud
for cloud secrets manager, and now in v0.13.0
we add the support for ViettelCloud
secrets manager. @hoangndst
LLM Ops with Inference Module for AI Applications
To simplify the process from Large Language Model (LLM) construction and deployment to the interaction with AI applications, KusionStack community has provided an inference
module. Users can use it as an accessory
to provide LLM service for AI applications. @kaysonyu
Bug Fixes
- Fix some bugs of json patch for workload to allow empty path on
add
andremove
, and skip the resources not found in theSpec
. @liu-hm19 - Fix some bugs of initializing the Kubernetes and Terraform runtime. @liu-hm19
- Fix some bugs of release update when executing the
kusion apply
andkusion destroy
. @liu-hm19 - Fix some bugs of not printing all the Kubernetes resources with multiple replicas while applying. @Yangyang96
New Contributors
- @EdenBW made their first contribution in #1251
- @ekjotsinghmakhija made their first contribution in #1235
- @Yangyang96 made their first contribution in #1268
- @kaysonyu made their first contribution in KusionStack/catalog#91
Docker Images
kusionstack/kusion:v0.13.0
v0.13.0-alpha.3
What's Changed
- feat: support removal env patcher by @liu-hm19 in #1281
- fix: init runtime with state by @liu-hm19 in #1288
- feat: add resource sub command by @Yangyang96 in #1291
- fix: print all the resources during watch in scenarios involving multiple replicas by @Yangyang96 in #1293
- feat: support max number of concurrent resource operation executions by @liu-hm19 in #1292
- fix: skip resources not found for json patch by @liu-hm19 in #1294
Full Changelog: v0.13.0-alpha.2...v0.13.0-alpha.3
v0.13.0-alpha.2
What's Changed
- fix: bugs of watching while apply by @liu-hm19 in #1279
- feat: kusion server update by @ffforest in #1269
- fix: swagger docs by @ffforest in #1283
- feat: add SecretStore field to GeneratorRequest by @hoangndst in #1284
Full Changelog: v0.13.0-alpha.1...v0.13.0-alpha.2
v0.13.0-alpha.1
What's Changed
- fix: typo in destroy.go and destroy_test.go filenames by @EdenBW in #1251
- fix: deep copy release to update when destroy by @liu-hm19 in #1252
- feat: bump kpm to v0.9.5 and upgrade related dependencies by @liu-hm19 in #1257
- feat: bump kcl go version to v0.10.0-alpha.3 by @liu-hm19 in #1258
- feat: remove requirement to use imported resource when apply by @hoangndst in #1260
- feat: add a new command kusion release list by @ekjotsinghmakhija in #1235
- feat: Viettel Cloud secrets manager by @hoangndst in #1267
- feat: add kusion release show command by @hoangndst in #1265
- feat: add KCL based customized health check by @Yangyang96 in #1268
- fix: json patch allows empty path on add and remove by @liu-hm19 in #1274
- fix: add rpc tag for builds in goreleaser by @liu-hm19 in #1275
New Contributors
- @EdenBW made their first contribution in #1251
- @ekjotsinghmakhija made their first contribution in #1235
- @Yangyang96 made their first contribution in #1268
Full Changelog: v0.12.1...v0.13.0-alpha.1
v0.12.1
Features
Optimize Storage Backend Management
In this version, we add support for AWS S3 path-style
endpoint for Kusion backend storage, and provide the new kusion release unlock
command to unlock the latest Release
file of the current Stack
. @hoangndst @liu-hm19
Optimize the Display of Sensitive Information
In previous versions, the kusion preview
and kusion apply
command would directly expose the plaintext data
and stringData
when displaying Kubernetes Secret
resources, posing a risk of sensitive information leakage. In this version, we have optimized the preview of the sensitive information, and the data
and stringData
of Kubernetes Secret
resources will not be displayed in plaintext. @liu-hm19
Optimize Terraform Cloud Resource Management
In this version, Kusion provides the ability to import existing cloud resources, and for the imported resources, Kusion will skip their deletion during kusion destroy
, as there may be multiple applications sharing the same resources. Additionally, Kusion also supports concurrent operations on independent Terraform resources, thereby improving the operational efficiency. @liu-hm19 @hoangndst @SparkYuan
Support Runtime Configurations in Workspace
In this version, users can declare the Kubernetes cluster configs and Terraform Provider credentials as runtime configurations in the context
field in Workspace
. @liu-hm19
Support Using Spec for Preview and Apply
In this version, Kusion supports using the Spec
file as the input for the kusion preview
and kusion apply
command. Users can specify a Spec
file in the Stack
directory with the --spec-file
flag. @liu-hm19
Workload Modularization
In the version of v0.12.0
, we have decoupled the schema definitions of Service
and Job
workloads separately from the codes of Kusion. And in this version, we have completely modularized the Workload
, both of the schema definitions and module generator implementations for Service
and Job
workloads have been moved to the catalog repository. And users can also implement their own customized Workload
modules according to their needs. @SparkYuan
Bug Fixes
- Fix a bug of volume directory overwrite @vietanhtwdk
- Fix a bug of reusing cached Terraform providers @SparkYuan
- Fix a bug of
JsonPatch
error message exposure @Liuxingyu1111111
New Contributors
- @hoangndst made their first contribution in #1189
- @vietanhtwdk made their first contribution in #1214
Docker Images
kusionstack/kusion:v0.12.1
Full Changelog: v0.12.0...v0.12.1
v0.12.1-rc.3
Changelog
- b0e216e: chore(deps): bump github.com/docker/docker (#1242) (@dependabot[bot])
- f6d89bb: feat: modularize workload (#1236) (@SparkYuan)
- 2c24840: feat: optimize terminal ui for kusion apply (#1241) (@liu-hm19)
- da2fc28: feat: support imported resources (#1238) (@liu-hm19)
- c772aed: feat: workload is no longer mandatory in the AppConfig (#1246) (@SparkYuan)
- 0186e14: fix: a bug of getting kubeconfig client (#1234) (@liu-hm19)
- 1d59d71: fix: duplicate equal sign in mod push cmd comments (#1244) (@adohe)
- 1953b6e: fix: return more detailed error msg with JsonPatch (#1245) (@Liuxingyu1111111)
Docker Images
kusionstack/kusion:0.12.1-rc.3
Dependent version
- kcl-go: ``
- kcl-plugin: ``
v0.12.1-rc.2
v0.12.1-rc.1
What's Changed
- fix: goreleaser deprecation notices by @liu-hm19 in #1163
- test: uncomment e2e tests by @SparkYuan in #1164
- docs: update the Chinese readme and the Windows download command by @SparkYuan in #1172
- feat: move secret references replacement form generating to applying by @SparkYuan in #1173
- fix: skip replacing secret data without ref prefix by @liu-hm19 in #1175
- feat: replace secret references in the preview by @SparkYuan in #1180
- feat: add support for on-premises secret provider define in api.kusion.io by @Liuxingyu1111111 in #1179
- chore(deps): bump github.com/docker/docker from 25.0.3+incompatible to 25.0.5+incompatible by @dependabot in #1184
- chore(deps): bump github.com/go-jose/go-jose/v3 from 3.0.2 to 3.0.3 by @dependabot in #1183
- chore(deps): bump github.com/hashicorp/go-retryablehttp from 0.7.5 to 0.7.7 by @dependabot in #1182
- feat: support spec file as input of preview and apply by @liu-hm19 in #1185
- feat: support path-style of bucket for s3 storage backend by @hoangndst in #1189
- ci: check md links periodically by @SparkYuan in #1193
- feat: support terraform resource import by @liu-hm19 in #1186
- feat: support release unlock command by @liu-hm19 in #1191
- feat: mask secret data in preview result by @liu-hm19 in #1176
- test: add windows e2e test by @liu-hm19 in #1197
- feat: enable concurrent manipulation of TF resources since they are stored in different directories by @SparkYuan in #1194
- fix: a TF breaking change to enable reusing cached providers by @SparkYuan in #1199
- chore(deps): bump github.com/hashicorp/go-getter from 1.7.4 to 1.7.5 by @dependabot in #1207
- chore(deps): bump google.golang.org/grpc from 1.64.0 to 1.64.1 by @dependabot in #1212
- fix: the latter volume dirs overwrite the prior one by @vietanhtwdk in #1214
- feat: support runtime configurations in workspace by @liu-hm19 in #1211
- fix: locked release file caused by interruption by @liu-hm19 in #1219
New Contributors
- @hoangndst made their first contribution in #1189
- @vietanhtwdk made their first contribution in #1214
Full Changelog: v0.12.0-rc.4...v0.12.1-rc.1