6738 Commits

Author SHA1 Message Date
HuijingHei
003cb99c32 karg-delete: support multiple times
Fix https://github.com/ostreedev/ostree/pull/2612#issuecomment-1764412141
2023-10-17 20:22:08 +08:00
Joseph Marrero Corchado
5d92407ba9
Merge pull request #3077 from cgwalters/debug-finalization-lock
deploy: Remove lock when re-staging
2023-10-13 16:05:44 -04:00
Colin Walters
ac69c70750 deploy: Remove lock when re-staging
This closes the biggest foot-gun when doing e.g.
`rpm-ostree rebase` when zincati is running on a FCOS system.

Previously if zincati happened to have staged + locked a deployment,
we'd keep around the lock which is definitely not what is desired.
2023-10-13 13:45:04 -04:00
Joseph Marrero Corchado
824ac1af0f
Merge pull request #3074 from cgwalters/more-errcontext-composefs
composefs: Add more error prefixing
2023-10-12 14:52:36 -04:00
Joseph Marrero Corchado
e75c5c6e41
Merge pull request #3073 from cgwalters/context-no-stateroot
deploy: Improve error message for nonexistent stateroot
2023-10-12 14:49:28 -04:00
Colin Walters
4a3e43c751 composefs: Add more error prefixing
To help debug https://github.com/coreos/rpm-ostree/issues/4649
2023-10-12 13:30:38 -04:00
Colin Walters
265b7f9ecc deploy: Improve error message for nonexistent stateroot
Came up on an internal chat; previously we were only erroring
out when trying to do the SELinux labeling for `/var` which
was really misleading.

Add some other error prefixing while we have the patient open.
2023-10-12 13:22:35 -04:00
Colin Walters
3894fe2ad6
Merge pull request #3062 from alexlarsson/transient-etc
Support transient /etc
2023-10-12 12:21:27 -04:00
Alexander Larsson
f617a341f3 Support transient /etc
If the `prepare-root.conf` file contains:
```
[etc]
transient=yes
```

Then during prepare-root, an overlayfs is mounted as /etc, with the
upper dir being in /run. If composefs is used, the lower dir is
`usr/etc` from the composefs image , or it is the deployed
`$deploydir/usr/etc`.

Note that for this to work with selinux, the commit must have been
built with OSTREE_REPO_COMMIT_MODIFIER_FLAGS_USRETC_AS_ETC. Otherwise
the lowerdir (/usr/etc) will have the wrong selinux contexts for the
final location of the mount (/etc).

We also set the transient-etc key in the ostree-booted file, pointing it
to the directory that is used for the overlayfs.

There are some additional work happening in ostree-remount, mostly
related to selinux (as this needs to happen post selinux policy
load):

 * Recent versions of selinux-poliy have issues with the overlayfs
   mount being kernel_t, and that is not allowed to manage files as
   needed. This is fixed in
   https://github.com/fedora-selinux/selinux-policy/pull/1893

 * Any /etc files created in the initramfs will not be labeled,
   because the selinux policy has not been loaded. In addition, the
   upper dir is on a tmpfs, and any manually set xattr-based selinux
   labels on those are reset during policy load. To work around this
   ostree-remount will relabel all files on /etc that have
   corresponding files in overlayfs upper dir.

 * During early boot, systemd mounts /run/machine-id on top of
   /etc/machine-id (as /etc is readonly). Later during boot, when etc
   is readwrite, systemd-machine-id-commit.service will remove the
   mount and update the real file under it with the right content. To
   ensure that this keeps working, we need to ensure that when we
   relabel /etc/machine-id we relabel the real (covered) file, not the
   temporary bind-mount.

 * ostree-remount no longer needs to remount /etc read-only in the
   transient-etc case.

Signed-off-by: Alexander Larsson <alexl@redhat.com>
2023-10-12 17:03:22 +02:00
Colin Walters
cd0fc9f4f8
Merge pull request #3072 from alexlarsson/fix-whiteout-test
tests: Fix whiteout test
2023-10-12 10:25:40 -04:00
Colin Walters
334f53d7e3
Merge pull request #3063 from cgwalters/label-usretc-as-etc
repo: Add an option to label /usr/etc as /etc
2023-10-12 07:57:05 -04:00
Alexander Larsson
397a11762e tests: Fix whiteout test
This test was always skipped, because the check:

 if touch overlay/baz/.wh.cow &&
    touch overlay/.wh.deeper &&
    touch overlay/baz/another/.wh..wh..opq; then

always fails due to the missing overlay/baz/another directory.
Fix by creating the directory.
2023-10-12 10:18:36 +02:00
Colin Walters
81c08746c6 repo: Add an option to label /usr/etc as /etc
This will be very useful for enabling a "transient /etc" option
because we won't have to do hacks relabling in the initramfs, or
forcing it on just for composefs.
2023-10-11 13:25:08 -04:00
Jonathan Lebon
6cce2e2381
Merge pull request #3067 from cgwalters/ci-composefs 2023-10-11 12:03:39 -04:00
Colin Walters
734ea3ee37 ci: Disable composefs test for now
Need to change the framework to boot with an Ignition config
that switches to ext4 soon.
2023-10-11 09:16:45 -04:00
Colin Walters
2f76b03089 ci: Ensure composefs+openssl are is enabled on Fedora
For some reason we're not picking this up in the Prow build,
which breaks things because now rpm-ostree hard requires it.

Let's make this a fatal build time error for more clear
debugging.
2023-10-06 13:12:23 -04:00
Colin Walters
befd84436c
Merge pull request #3060 from owtaylor/export-hardlinks
When exporting, use hardlinks for duplicated files
2023-10-03 10:08:36 -04:00
Owen W. Taylor
3b2fd6e9ff When exporting, use hardlinks for duplicated files
For ostree_repo_export_tree_to_archive(), and 'ostree export', when the
exported tree contains multiple files with the same checksum, write an
archive with hard links.

Without this, importing a tree, then exporting it again breaks
hardlinks.

As an example of savings: this reduces the (compressed) size of the
Fedora Flatpak Runtime image from 1345MiB to 712MiB.

Resolves: #2925
2023-09-29 13:45:29 -04:00
Colin Walters
8c25452c1e
Merge pull request #3049 from jlebon/pr/revert-virtiofs-hack
Revert "ci: Run cosa unprivileged"
2023-09-28 09:12:44 -04:00
Jonathan Lebon
2363de7100
Merge pull request #3059 from cgwalters/zipl-default-s390x 2023-09-28 08:18:16 -04:00
Jonathan Lebon
b8ce61ba7b Revert "ci: Run cosa unprivileged"
This reverts commit 2fe88f80fae83e206f811003a072c73ceebcea59.

This shouldn't be necessary now with the workaround built in cosa:

https://github.com/coreos/coreos-assembler/pull/3625
2023-09-27 19:35:58 -04:00
Colin Walters
c4dcfbaecd
Merge pull request #3046 from ostreedev/dependabot/submodules/composefs-cca8be4
build(deps): bump composefs from `af86742` to `cca8be4`
2023-09-27 19:34:30 -04:00
Colin Walters
e3d93a8571 repo: Default bootloader to zipl on s390x
This will allow us to drop code like
87fc693c11/src/create_disk.sh (L503)
which is really just unnecessary since there aren't any other
bootloaders we care about on this architecture.
2023-09-27 18:10:15 -04:00
Joseph Marrero Corchado
ec7bc823eb
Merge pull request #3058 from cgwalters/doc-authenticated-repos
docs: Add authenticated-repos.md
2023-09-27 15:27:26 -04:00
Colin Walters
d4adb79539 docs: Add authenticated-repos.md
Document options for accessing repositories that require authentication.
2023-09-27 14:02:55 -04:00
Colin Walters
13be0786bb
Merge pull request #3021 from cgwalters/insttest-composefs-binding
tests: Add an integration test for composefs signatures
2023-09-21 19:50:05 -04:00
Colin Walters
46b7821d0c
Merge pull request #3053 from ericcurtin/add_overlay_and_erofs_to_initrd
boot/dracut: Add erofs and overlayfs kernel modules
2023-09-21 13:13:27 -04:00
Eric Curtin
cecb59dd53 boot/dracut: Add erofs and overlayfs kernel modules
These kernel modules are required for composefs usage in the initramfs.

The composefs use-case as of today uses an overlayfs on top of EROFS.
2023-09-21 12:03:07 -04:00
Colin Walters
372cbd7a64 tests: Add an integration test for composefs signatures
Ensure we have some automated test coverage for this.
2023-09-21 07:53:19 -04:00
Eric Curtin
cd606aa6fe
Merge pull request #3051 from cgwalters/rust-tests-update
rust/tests: Adjust for new ostree
2023-09-20 14:18:31 +01:00
Colin Walters
87c4367806
Merge pull request #3052 from cgwalters/switch-libglnx-source
gitmodules: Use github GNOME mirror
2023-09-20 08:48:17 -04:00
Colin Walters
01a847a2d1 gitmodules: Use github GNOME mirror
gitlab.gnome.org is down right now, but it's been somewhat
flaky in the past.  Our CI uptime becomes an *intersection*
of all systems it depends on, and by cutting out gitlab.gnome.org
we increase its reliability.
2023-09-20 07:58:44 -04:00
Colin Walters
e3291ccce9 tests: Rework detection of trivial-httpd
Because it's now at the toplevel.
2023-09-19 16:52:13 -04:00
Jonathan Lebon
878d601665
Merge pull request #3047 from ostreedev/dependabot/submodules/libglnx-aff1eea 2023-09-18 11:08:13 -04:00
dependabot[bot]
ff73bebc74
build(deps): bump libglnx from 54ad67d to aff1eea
Bumps libglnx from `54ad67d` to `aff1eea`.

---
updated-dependencies:
- dependency-name: libglnx
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2023-09-18 12:18:48 +00:00
dependabot[bot]
7916cfb68d
build(deps): bump composefs from af86742 to cca8be4
Bumps [composefs](https://github.com/containers/composefs) from `af86742` to `cca8be4`.
- [Release notes](https://github.com/containers/composefs/releases)
- [Commits](af86742579...cca8be4984)

---
updated-dependencies:
- dependency-name: composefs
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2023-09-18 12:18:47 +00:00
Jonathan Lebon
92d25eb56b
Merge pull request #3039 from cgwalters/rust-switch-include 2023-09-12 09:10:11 -04:00
Colin Walters
26dcd4f575 rust: Switch to using include
This way we don't randomly pick up bits from the C library
unintentionally as things change on that side.

I think the support for `!` in `include` may be relatively new
and that's why the original author here chose to do things
via `exclude`.  But using `include` with a few specific exclusions
is just way better.
2023-09-11 17:16:41 -04:00
Colin Walters
b7e39eba07
Merge pull request #2054 from jlebon/pr/static-delta-fetch-no-scan
lib/pull: Don't scan commit objects we fetch via deltas
2023-09-11 09:41:13 -04:00
Jonathan Lebon
cd116a1e63 lib/pull: Drop static delta superblocks references
We don't need them long-lived anymore. They were just used for reporting
at this point, but we can use the new `static_delta_targets` hash table
size for that now.
2023-09-10 22:17:13 -04:00
Jonathan Lebon
2fe88f80fa ci: Run cosa unprivileged
As a workaround for a virtiofs bug:
https://gitlab.com/virtio-fs/virtiofsd/-/merge_requests/197

xref coreos/coreos-assembler#3428 (comment)

Just like in https://github.com/coreos/rpm-ostree/pull/4585.
2023-09-08 21:09:09 -04:00
Jonathan Lebon
fc5aef6fe6 lib/pull: Don't scan commit objects we fetch via deltas
When we're fetching a commit via static delta, we already take care of
fetching the full commit, so there's no need to also scan it using the
regular object workflow.

Closes: #2053
2023-09-08 17:49:25 -04:00
Jonathan Lebon
c8ed1c7a87 lib/pull: Fix miscounting of missing metadata
If e.g. detached metadata or a parent commit is missing, we
don't consider it an error but we erroneously still increment the
`n_fetched_metadata` counter, causing it to be higher than it should.

This will implicitly be tested by a test added in the next patch.
2023-09-08 17:49:25 -04:00
Jonathan Lebon
3c2587b619 app/pull-local: Add --disable-static-delta
For completeness with `pull`.

Prep for using it in testing to assert we'll never use static deltas.
2023-09-08 15:07:29 -04:00
Colin Walters
0ac8795686
Merge pull request #3038 from cgwalters/rust-drop-composefs
rust: Drop composefs from crate
2023-09-08 12:03:21 -04:00
Eric Curtin
6a94856729
Merge pull request #3037 from cgwalters/add-labeler-flow
ci: Add an automatic labeler action
2023-09-08 12:52:44 +01:00
Colin Walters
2db17d2107 rust: Drop composefs from crate
This greatly reduces the size.  TODO: switch to using `include`.
2023-09-08 07:38:31 -04:00
Colin Walters
749857df67
Merge pull request #3035 from cgwalters/release-rust
rust/sys: Also bump semver for this
2023-09-08 07:24:56 -04:00
Colin Walters
129969482e ci: Add an automatic labeler action
To automate a bit.
2023-09-07 17:38:59 -04:00
Colin Walters
1714e8371f
Merge pull request #3030 from ostreedev/dependabot/submodules/composefs-af86742
build(deps): bump composefs from `d085fbf` to `af86742`
2023-09-07 16:21:39 -04:00