- Update to version 0.11.1+0:
* Fixed a security vulnerability that could allow an attacker to
execute an arbitrary binary under certain conditions. Plugin
names are now required to only contain alphanumeric characters
or the four special characters +-._.
* Replace the test `NoCallbacks` with the library version
* Restrict set of valid characters for plugin names
* Add tests for invalid plugin name chars
- Update to 0.11.0+0:
Added:
* Partial French translation!
Fixed:
* [Unix] Files can now be encrypted with rage --passphrase when
piped over stdin, without requiring an explicit - argument as
INPUT.
- bsc#1229959 - RUSTSEC-2024-0006 - CVE-2024-43806
- rust-shlex: Multiple issues involving quote API
- bsc#1229959 - RUSTSEC-2024-0006 - rust-shlex: Multiple issues involving quote API
- Enable tests
- Install all language manpages
- Fix -keygen installing to -mount
- Switch from obsoleted practices to modern ones:
* %setup is now %autosetup
* cargo_config is now part of vendor file
* disabledrun is now manualrun
- Update to version 0.10.0+0:
Added:
* Russian translation
* rage-keygen -y IDENTITY_FILE to convert identity files to
recipients.
Changed:
* MSRV is now 1.65.0.
* Migrated from gumdrop to clap for argument parsing.
* -R/--recipients-file and -i/--identity now support "read-once"
files, like those used by process substitution (-i
<(other_binary get-age-identity)) and named pipes.
* The filename - (hyphen) is now treated as an explicit request
to read from standard input when used with -R/--recipients-file
or -i/--identity. It must only occur once across the
-R/--recipients-file and -i/--identity flags, and the input
file. It cannot be used if the input file is omitted.
Fixed:
* OpenSSH private keys passed to -i/--identity that contain
invalid public keys are no longer ignored when encrypting, and
instead cause an error.
* Weak ssh-rsa public keys that are smaller than 2048 bits are
now rejected.
* rage-keygen no longer overwrites existing key files with the
-o/--output flag. This was its behaviour prior to 0.6.0, but
was unintentionally changed when rage was modified to overwrite
existing files. Key file overwriting can still be achieved by
omitting -o/--output and instead piping stdout to the file.
* rage-keygen now prints fatal errors directly instead of them
being hidden behind the RUST_LOG=error environment variable. It
also now sets its return code appropriately instead of always
returning 0.
- bsc#1215657 - chosen ciphertext attack possible against aes-gcm
* update vendor.tar.zst to contain aes-gcm >= 0.10.3
- Update to version 0.9.2+0:
* CI: Ensure `apt` repository is up-to-date before installing build deps
* CI: Build Linux releases using `ubuntu-20.04` runner
* CI: Remove most uses of `actions-rs` actions
- Update to version 0.9.2+0:
* v0.9.2
* Fix changelog bugs and add missing entry
* Document `PINENTRY_PROGRAM` environment variable
* age: Add `Decryptor::new_async_buffered`
* age: `impl AsyncBufRead for ArmoredReader`
* Pre-initialize vectors when the capacity is known, or use arrays
* Use `PINENTRY_PROGRAM` as environment variable for `pinentry`
* Document why `impl AsyncWrite for StreamWriter` doesn't loop indefinitely
* cargo update
* cargo vet prune
* Migrate to `cargo-vet 0.7`
* build(deps): bump svenstaro/upload-release-action from 2.5.0 to 2.6.1
* Correct spelling in documentation
* build(deps): bump codecov/codecov-action from 3.1.1 to 3.1.4
* StreamWriter AsyncWrite: fix usage with futures::io::copy()
* rage: Use `Decryptor::new_buffered`
* age: Add `Decryptor::new_buffered`
* age: `impl BufRead for ArmoredReader`
* Update Homebrew formula to v0.9.1
* feat/pinentry: Use env var to define pinentry binary
- As per https://en.opensuse.org/openSUSE:Package_description_guidelines
mention distinctive characteristics that offset this solution
from e.g. gpg.
- Update to version 0.9.1+0:
* ssh: Fix parsing of OpenSSH private key format
* ssh: Support `aes256-gcm@openssh.com` ciphers for encrypted keys
* ssh: Add `aes256-gcm@openssh.com` cipher to test cases
* ssh: Extract common key material derivation logic for encrypted keys
* ssh: Use associated constants for key and IV sizes
* ssh: Add test cases for encrypted keys
- Add shell completions for fish and zsh.
- bsc#1207039 - CVE-2023-22895 - update bzip2 crate
- Update of vendored dependencies
- Update of vendored dependencies
- Do not have the main package recommend the bash-completion
sub-package, but rather have the subpackage supplement the
combination of tage-encryption and bash-completion.
- Update to version 0.9.0+0:
* v0.9.0
* use pkcs1 crate to parse RSAPrivateKey ASN.1 object
* qa: Add workflow that runs `cargo vet --locked`
* qa: Import `cargo vet` audits from Firefox and zcashd
* qa: Add `crypto-reviewed` criteria or `cargo vet`
* qa: `cargo vet init`
- Set minimum rust requirement to 1.59
- Update to version 0.8.1+0:
* v0.8.1
* Revert updates to `dashmap` and `indexmap`
* cargo update
* age: Add passphrase to scrypt_work_factor_23 testkit test file
* age: Reject invalid or non-canonical X25519 recipient stanzas
* age: Require "contributory" behaviour for X25519 recipient stanzas
* age: Add testkit test files from reference impl
* Update Homebrew formula to v0.8.0
- Update to version 0.8.0+0:
* v0.8.0
* age: Allow ciphertexts that encrypt the empty plaintext
* Update Italian translation
* Don't allow -i/--identity with passphrase-encrypted files
* age: Require the last STREAM chunk to be non-empty
* age: Return correct response encoding for `confirm` command
* age: Base64-decode metadata arguments to "confirm" message
* age: Extract "confirm" command handling into a helper function
- Automatic update of vendored dependencies
- Update to resolve bsc#1196972 CVE-2022-24713 - Regex DOS
- switched to vendored_licenses_packager as build dependency
- define macro "rust_tier1_arches" if undefined
- Add specific lock file path to _service for cargo audit to prevent
confusion with the lock files in the fuzz folders.
- Update to version 0.7.1
* Fixed a bug where non-canonical recipient stanza bodies in an age
file header would cause rage to crash instead of being rejected
* vendor.tar.xz updated from source code Cargo.lock file
- Added:
* binary rage-mount
* bash-completion for rage, rage-keygen and rage-mount
* manual pages for rage, rage-keygen and rage-mount
* Licenses files
* Licenses files of vendored crates extracted
with script "vendored_licenses_packager.sh"
* README and CHANGELOG files
* possibility to build without cargo-packaging for "older" distros
- Update to version 0.7.0~git0.c93b914:
* v0.7.0
* cargo update fuzz*
* Update lockfiles for fuzzers
* rage: Pin clap to 3.0.0-beta.2
* CI: Add bitrot check to ensure examples and benchmarks still compile
* console 0.15
* age: Re-export `secrecy` crate
* age-core: Improve crate documentation
* age-core: Re-export `secrecy` crate
* age-core: Add `plugin::Error` enum
- Initial commit of rage
OBS-URL: https://build.opensuse.org/package/show/security/rage-encryption?expand=0&rev=39
157 lines
5.0 KiB
RPMSpec
157 lines
5.0 KiB
RPMSpec
#
|
|
# spec file for package rage-encryption
|
|
#
|
|
# Copyright (c) 2024 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
%{?!rust_tier1_arches:%global rust_tier1_arches x86_64 aarch64}
|
|
|
|
Name: rage-encryption
|
|
# This will be set by osc services, that will run after this.
|
|
Version: 0.11.1+0
|
|
Release: 0
|
|
Summary: X25519-based, simple, modern, and secure file encryption tool
|
|
# If you know the license, put it's SPDX string here.
|
|
# Alternately, you can use cargo lock2rpmprovides to help generate this.
|
|
License: (0BSD OR MIT OR Apache-2.0) AND (Apache-2.0 OR BSL-1.0) AND (Apache-2.0 OR MIT) AND (Apache-2.0 OR MIT OR Zlib) AND (MIT OR Unlicense) AND (Apache-2.0 OR Zlib OR MIT) AND Apache-2.0 AND BSD-3-Clause AND CDDL-1.0 AND MIT
|
|
# Select a group from this link:
|
|
# https://en.opensuse.org/openSUSE:Package_group_guidelines
|
|
Group: Productivity/Security
|
|
URL: https://github.com/str4d/rage
|
|
Source0: rage-%{version}.tar.gz
|
|
Source1: vendor.tar.zst
|
|
%if %{suse_version} > 1500
|
|
BuildRequires: cargo-packaging
|
|
%endif
|
|
# Requires >1.59 for thread::available_parallelism
|
|
BuildRequires: cargo >= 1.59
|
|
BuildRequires: libzstd-devel
|
|
BuildRequires: vendored_licenses_packager
|
|
# for feature mount
|
|
BuildRequires: fuse-devel
|
|
Recommends: pinentry
|
|
BuildRequires: zstd
|
|
Conflicts: rage
|
|
ExclusiveArch: %{rust_tier1_arches}
|
|
|
|
%description
|
|
Rage is a simple, modern, and secure file encryption tool, using the
|
|
age format. It features small explicit keys, no config options, and
|
|
UNIX-style composability.
|
|
|
|
Keys are based on X25519 which are similar to the ones used by SSH.
|
|
rage-encryption can also use ssh-ed25519 and ssh-rsa keys as
|
|
alternatives to age1 keys.
|
|
|
|
%package bash-completion
|
|
Summary: Bash completion for %{name}
|
|
Group: Productivity/Security
|
|
BuildArch: noarch
|
|
Requires: %{name}
|
|
Requires: bash-completion
|
|
Supplements: (%{name} and bash-completion)
|
|
Conflicts: rage
|
|
|
|
%description bash-completion
|
|
Bash command line completion support for %{name}
|
|
|
|
%package fish-completion
|
|
Summary: Fish Completion for %{name}
|
|
Group: Productivity/Security
|
|
Supplements: (%{name} and fish)
|
|
Requires: fish
|
|
BuildArch: noarch
|
|
|
|
%description fish-completion
|
|
Fish command-line completion support for %{name}.
|
|
|
|
%package zsh-completion
|
|
Summary: Zsh Completion for %{name}
|
|
Group: Productivity/Security
|
|
Supplements: (%{name} and zsh)
|
|
Requires: zsh
|
|
BuildArch: noarch
|
|
|
|
%description zsh-completion
|
|
Zsh command-line completion support for %{name}.
|
|
|
|
%prep
|
|
%autosetup -a 1 -n rage-%{version}
|
|
%vendored_licenses_packager_prep
|
|
|
|
%build
|
|
%define build_args --manifest-path rage/Cargo.toml --features "mount" --release %{?_smp_mflags}
|
|
|
|
%if %{suse_version} > 1500
|
|
%{cargo_build} --features "mount"
|
|
%else
|
|
cargo build %{build_args}
|
|
%endif
|
|
|
|
%check
|
|
%if %{suse_version} > 1500
|
|
%{cargo_test} --features "mount"
|
|
%else
|
|
cargo test %{build_args}
|
|
%endif
|
|
|
|
%install
|
|
pushd target/release
|
|
|
|
# Install each part of the tool and their respective completions.
|
|
for i in "" -keygen -mount; do
|
|
install -D -m 0755 rage$i %{buildroot}%{_bindir}/rage$i
|
|
install -D -p -m 644 completions/rage$i.bash %{buildroot}%{_datadir}/bash-completion/completions/rage$i
|
|
install -D -p -m 644 completions/_rage$i %{buildroot}%{_datadir}/zsh/site-functions/_rage$i
|
|
install -D -p -m 644 completions/rage$i.fish %{buildroot}%{_datadir}/fish/vendor_completions.d/rage$i.fish
|
|
done
|
|
|
|
pushd manpages
|
|
mv es_AR es # es_AR doesn't seem to be a correct manpage locale
|
|
find . -name "*.1.gz" -exec install -Dpm644 {} %{buildroot}%{_mandir}/{} \;
|
|
popd
|
|
popd
|
|
|
|
%vendored_licenses_packager_install
|
|
%find_lang rage{,-keygen,-mount} rage.lang --with-man --all-name
|
|
|
|
%files -f rage.lang
|
|
%{_bindir}/rage
|
|
%{_bindir}/rage-keygen
|
|
%{_bindir}/rage-mount
|
|
%doc README.md rage/CHANGELOG.md
|
|
# accept duplicates here
|
|
%license LICENSE-APACHE LICENSE-MIT
|
|
%vendored_licenses_packager_files
|
|
%{_mandir}/man1/rage*.1%{?ext_man}
|
|
|
|
%files bash-completion
|
|
%license LICENSE-APACHE LICENSE-MIT
|
|
%{_datadir}/bash-completion/completions/rage*
|
|
|
|
%files fish-completion
|
|
%license LICENSE-APACHE LICENSE-MIT
|
|
%dir %{_datadir}/fish
|
|
%dir %{_datadir}/fish/vendor_completions.d
|
|
%{_datadir}/fish/vendor_completions.d/rage*.fish
|
|
|
|
%files zsh-completion
|
|
%license LICENSE-APACHE LICENSE-MIT
|
|
%dir %{_datadir}/zsh
|
|
%dir %{_datadir}/zsh/site-functions
|
|
%{_datadir}/zsh/site-functions/_rage*
|
|
|
|
%changelog
|