Changelog¶
4.8.2 (2025-Jan-16)¶
Application¶
Fix an issue with processing fetch-service output.
For a complete list of commits, check out the 4.8.2 release on GitHub.
4.8.1 (2025-Jan-13)¶
Application¶
Do not log encoded secrets in managed mode if
build_secrets
AppFeature
is enabled.
Documentation¶
Add missing links to the GitHub releases.
For a complete list of commits, check out the 4.8.1 release on GitHub.
4.8.0 (2025-Jan-13)¶
Services¶
Fix a bug where the same build environment was reused for platforms with the same build-on and build-for architectures.
Utils¶
Add
format_timestamp()
helper that helps with formatting time in command responses.Add
is_managed_mode()
helper to check if running in managed mode.Add
get_hostname()
helper to get a name of current host.
For a complete list of commits, check out the 4.8.0 release on GitHub.
4.7.0 (2024-Dec-19)¶
Application¶
Allow applications to implement multi-base build plans.
For a complete list of commits, check out the 4.7.0 release on GitHub.
4.6.0 (2024-Dec-13)¶
Application¶
Add support for keeping order in help for commands provided to
add_command_group()
.Add support for rock launchpad recipes, allowing the remote build of rocks.
Commands¶
Add a
remote-build
command. This command is not registered by default, but is available for application use.
Git¶
Extend the
craft_application.git
module with the following APIs:Add
is_commit(ref)
andis_short_commit(ref)
helpers for checking if a given ref is a valid commit hash.Add a
Commit
model to represent the result ofget_last_commit()
.
Extend the
GitRepo
class with additional methods:Add
set_remote_url()
andset_remote_push_url()
methods and their getter counterparts.Add
set_no_push()
method, which explicitly disablespush
for specific remotes.Add
get_last_commit()
method, which retrieves the last commit hash and message.Add
get_last_commit_on_branch_or_tag()
method, which retrieves the last commit associated with a given ref.Add
fetch()
method, which retrieves remote objects.
Use
craft.git
for Git-related operations run withsubprocess
inGitRepo
.
For a complete list of commits, check out the 4.6.0 release on GitHub.
4.5.0 (2024-Nov-28)¶
Application¶
The fetch-service integration now assumes that the fetch-service snap is tracking the
latest/candidate
.Fix an issue where the fetch-service output was not correctly logged when running in a snapped craft tool.
Commands¶
Provide a documentation link in help messages.
Updates to the
init
command:If the
--name
argument is provided, the command now checks if the value is a valid project name, and returns an error if it isn’t.If the
--name
argument is not provided, the command now checks whether the project directory is a valid project name. If it isn’t, the command sets the project name tomy-project
.
Services¶
Add version to the template generation context of
InitService
.
For a complete list of commits, check out the 4.5.0 release on GitHub.
4.4.0 (2024-Nov-08)¶
Application¶
AppCommand
subclasses now will always receive a validapp_config
dict.Fixes a bug where the fetch-service integration would try to spawn the fetch-service process when running in managed mode.
Cleans up the output from the fetch-service integration.
Commands¶
Adds an
init
command for initialising new projects.Lifecycle commands are ordered in the sequence they run rather than alphabetically in help messages.
Preserves order of
CommandGroups
defined by the application.Applications can override commands defined by Craft Application in the same
CommandGroup
.
Services¶
Adds an
InitService
for initialising new projects.
For a complete list of commits, check out the 4.4.0 release on GitHub.
4.3.0 (2024-Oct-11)¶
Application¶
Added compatibility methods for craft-platforms models.
Commands¶
The
clean
command now supports the--platform
argument to filter which build environments to clean.
Services¶
Added an experimental integration with the fetch-service, to generate manifests listing assets that were downloaded during the build.
For a complete list of commits, check out the 4.3.0 release on GitHub.
4.2.7 (2024-Oct-08)¶
Don’t depend on requests >= 2.32.0.
Fix: set CRAFT_PARALLEL_BUILD_COUNT correctly in
override-
scripts.
For a complete list of commits, check out the 4.2.7 release on GitHub.
4.2.6 (2024-Oct-04)¶
Remove the
requests<2.32.0
constraint to resolve CVE-2024-35195.
For a complete list of commits, check out the 4.2.6 release on GitHub.
4.2.5 (2024-Oct-04)¶
Services¶
The config service handles snap issues better.
For a complete list of commits, check out the 4.2.5 release on GitHub.
4.2.4 (2024-Sep-19)¶
Remote build¶
Remote build errors are now a subclass of
CraftError
.
For a complete list of commits, check out the 4.2.4 release on GitHub.
4.2.3 (2024-Sep-18)¶
Application¶
get_arg_or_config
now correctly checks the config service if the passed namespace hasNone
as the value of the requested item.
For a complete list of commits, check out the 4.2.3 release on GitHub.
4.2.2 (2024-Sep-13)¶
Application¶
Add a
_run_inner
method to override or wrap the core run logic.
For a complete list of commits, check out the 4.2.2 release on GitHub.
4.2.1 (2024-Sep-13)¶
Models¶
Fix a regression where numeric part properties could not be parsed.
For a complete list of commits, check out the 4.2.1 release on GitHub.
4.1.3 (2024-Sep-12)¶
Models¶
Fix a regression where numeric part properties could not be parsed.
For a complete list of commits, check out the 4.1.3 release on GitHub.
4.2.0 (2024-Sep-12)¶
Application¶
Add a configuration service to unify handling of command line arguments, environment variables, snap configurations, and so on.
Use the standard library to retrieve the host’s proxies.
Commands¶
Properly support
--shell
,--shell-after
and--debug
on thepack
command.
For a complete list of commits, check out the 4.2.0 release on GitHub.
4.1.2 (2024-Sep-05)¶
Application¶
Managed runs now fail if the build plan is empty.
Error message tweaks for invalid YAML files.
Models¶
Platform models now correctly accept non-vectorised architectures.
For a complete list of commits, check out the 4.1.2 release on GitHub.
4.1.1 (2024-Aug-27)¶
Application¶
When a build fails due to matching multiple platforms, those matching platforms will be specified in the error message.
Show nicer error messages for invalid YAML files.
For a complete list of commits, check out the 4.1.1 release on GitHub.
4.1.0 (2024-Aug-14)¶
Application¶
If an app isn’t running from snap, the installed app will install the snap
in the provider using the channel in the CRAFT_SNAP_CHANNEL
environment
variable, defaulting to latest/stable
if none is set.
Services¶
The LifecycleService
now breaks out a _get_build_for
method for
apps to override if necessary.
For a complete list of commits, check out the 4.1.0 release on GitHub.
4.0.0 (2024-Aug-09)¶
Breaking changes¶
This release migrates to pydantic 2.
Most exit codes use constants from the os
module. (This makes
craft-application 4 only compatible with Windows when using Python 3.11+.)
Models¶
Add constrained string fields that check for SPDX license strings or the license string “proprietary”.
CraftBaseModel now includes a to_yaml_string
method.
Custom regex-based validators can be built with
models.get_validator_by_regex
. These can be used to make a better error
message than the pydantic default.
Git¶
The git
submodule under launchpad
is now its own module and can clone
repositories and add remotes.
For a complete list of commits, check out the 4.0.0 release on GitHub.
3.2.0 (2024-Jul-07)¶
Application¶
Add support for versioned documentation urls - that is, urls that point to the documentation for the specific version of the running application.
Documentation¶
Add a how-to guide for using partitions.
For a complete list of commits, check out the 3.2.0 release on GitHub.
3.1.0 (2024-Jul-05)¶
Note
3.1.0 includes changes from the 2.9.0 release.
Remote build¶
Add a credentials_filepath
property to the RemoteBuildService
so that
applications can point to a different Launchpad credentials file.
For a complete list of commits, check out the 3.1.0 release on GitHub.
2.9.0 (2024-Jul-03)¶
Application¶
Support doc slugs for craft-parts build errors, to point to the plugin docs.
Support setting the base docs url on the AppMetadata, used in conjunction with slugs to build full urls.
Add a method to enable craft-parts Features. This is called at a specific point so that things like command groups can rely on the features being set.
Ensure the craft-providers’ provider is available before launching.
Models¶
Fix and normalize project validation errors. Never raise CraftValidationErrors directly in validators.
Add a way to provide doc slugs for models. These are shown when a project fails validation, provided the base docs url is set on the AppMetadata.
3.0.0 (2024-Jun-28)¶
Craft Application 3.0.0 implements the BuildPlanner
class and can create
a build plan. This is a breaking change because it requires more fields to
be defined.
Warning
platforms
is now a required field in the Project
platforms
, base
, and build-base
are now required fields in the
BuildPlanner
model
Application¶
Extends
add_command_groups()
to accept a sequence instead of a list.Adds support for building architecture-independent artefacts by accepting
all
as thebuild-for
target.
Models¶
Adds a default
Platform
model. See platforms for a reference of the model.Adds a default
get_build_plan()
function to theBuildPlanner
class. See Build plans for an explanation of how the defaultget_build_plan()
works.Changes
BuildPlanner
from an abstract class to a fully implemented class. Applications can now use theBuildPlanner
class directly.
For a complete list of commits, check out the 3.0.0 release on GitHub.
2.8.0 (2024-Jun-03)¶
Commands¶
Fixes a bug where the pack command could accept a list of parts as command line arguments.
Adds support for commands to accept multiple
platform
orbuild-for
values from the command line as comma-separated values.
Remote build¶
Retries more API calls to Launchpad.
Adds an exponential backoff to API retries with a maximum total delay of 62 seconds.
Fixes a bug where the full project name was not used in the remote build log files.
For a complete list of commits, check out the 2.8.0 release on GitHub.
2.7.0 (2024-May-08)¶
Base naming convention¶
Applications that use a non-default base naming convention must implement
Project._providers_base()
to translate application-specific base names into
a Craft Providers base.
The default base naming convention is <distribution>@<series>
. For example,
ubuntu@24.04
, centos@7
, and almalinux@9
.
LifecycleCommand¶
Adds a new LifecycleCommand
class that can be inherited for creating
application-specific lifecycle commands.
_needs_project()
¶
Adds a new command function _needs_project()
that can be overridden by
subclasses. It’s similar to the always_load_project
class variable but takes
parsed_args
as a parameter. The default value is always_load_project
.
For a complete list of commits, check out the 2.7.0 release on GitHub.