- Default type for CLI arg
--run-timeout
to avoid type mismatch (#626) - Dependency update (#627)
- CLI argument to control command execution timeout (#605)
- ITE-4 resolver for directories ("dirHash", #590)
- Lint configuration (#602)
- Output stream cleanup to address flaky tests on Windows (#597)
- Layout expiry condition (#616)
- Dependency updates (#604, #607, #608, #609, #617, #618, #619, #620, #622, #623)
- AppVeyor test configuration (#598)
This release includes breaking changes such as the removal of the user_settings module and changes to exceptions raised during artifact recording. Additionally, it incorporates changes for issues captured in security advisories GHSA-p86f-xmg6-9q4x, GHSA-jjgp-whrp-gq8m, and GHSA-wc64-c5rv-32pf, the last of which has been assigned CVE-2023-32076.
- Generic interface for ITE-4 resolvers (#584)
- ITE-4 resolver for OSTree repositories (#585)
- Warning when
--bits
is used with non RSA keys inin-toto-keygen
(#588) - Support for GitHub's security reporting feature (#567)
- Tool to check local artifacts against in-toto link metadata (#589, GHSA-p86f-xmg6-9q4x)
- Testing in CI for Python 3.11 (#594)
- Recording of file hashes to use ITE-4 file resolver (#584)
- Exceptions returned to Python defaults when recording file artifacts (#592)
- Documentation about in-toto governance to reflect project changes (#591)
- Code style to use black + isort, includes update to codebase to conform (#593)
- Verification documentation to reflect how PGP trust model is used (GHSA-jjgp-whrp-gq8m)
- Support for user_settings module that enabled configuring in-toto via RC files and environment variables (GHSA-wc64-c5rv-32pf)
- Support for DSSE in metadata generation tools (#503, #577)
- Ability to set command, byproducts, environment in the in_toto_record APIs (#564)
- Various dependency updates and dependabot changes
- Simplified link threshold check (#573)
- Moved subprocess execution wrapper to in-toto from securesystemslib (#544)
- Support for in-toto flavoured GPGSigner and GPGKey for use with securesystemlib's new signer API (#538)
- Acknowledgement to Purdue University (#526)
- Invocation of bandit linter (#541)
- Link to in-toto specification in README (#551)
- Dependency updates (#543, #549)
- Includes tests in source distribution
- ECDSA key type in CLI (#520)
- Windows builds in GitHub Actions CI (#513)
- Dependabot version monitoring for GitHub Actions (#498)
- Build is now reproducible, thanks to hatchling (#490)
- Misc test updates (#487, #500, #529)
- Misc docs updates (#499, #512, #516, #515, #530)
- Obsolete test dependency (#521)
- Bump dependencies: attrs (#482), cffi (#474), cryptography (#468, #472, #477, #481), iso8601 (#476, #478, #479), pycparser (#475), pynacl (#483), securesystemslib (#469)
- Use explicit UTF-8 encoding in open calls (#470)
- Misc. linter changes (#473)
- Update acknowledgment to reflect Purdue (#471)
- Python 3.6 support (#485)
- Added tests that use source and destination prefixes in match rules, courtesy of Brandon Michael Hunter (#456)
- Updated documentation of command alignment during verification workflow (#455)
- Started using GitHub-native dependabot ($450)
- Bump dependencies: attrs (#451), six (#452), securesystemslib (#453), cffi (#457), python-dateutil (#458), iso8601 (#459), pathspec (#460)
- Fixed linter warnings (#462)
NOTE: this release of in-toto drops supports for Python 2.7. This is because Python 2.7 was marked end-of-life in January of 2020, and since then several of in-toto's direct and transitive dependencies have stopped supporting Python 2.7.
- SPDX License identifiers and copyright information (#440)
- Aditya Sirish (@adityasaky) as a maintainer (#443)
- PyPI development status from
Beta
toProduction/Stable
(#447) - Santiago Torres-Arias's (@SantiagoTorres) email to reflect Purdue affiliation (#446)
- Debian downstream release metadata (#437)
- Bump dependency: cryptography (#442)
- Dropped support for Python 2.7 (#438)
NOTE: this will be the final release of in-toto that supports Python 2.7. This is because Python 2.7 was marked end-of-life in January of 2020, and since then several of in-toto's direct and transitive dependencies have stopped supporting Python 2.7.
- Python 3.9 in the CI test matrix (#419)
- Logo and other visual enhancements on readthedocs (#420, #428)
- Review of first evaluation period for 2021 roadmap (#421)
- Switch to GitHub Actions for CI (#432)
- Switch to only running bandit on Python versions greater than 3.5 (#416)
- Debian downstream release metadata (#418)
- Bump tested dependencies: cffi (#415, #427), cryptography (#424, #429), securesystemslib (#430, #431), iso8601 (#423) NOTE: the latest version of cryptography is no longer used on Python 2, as that is not supported.
- Dropped support for Python 3.5 (#419)
- '-P/--password' (prompt) cli argument for in-toto-run/in-toto-record (#402)
- in-toto-run link command timeout setting (#367)
- API and usage documentation for cryptographic key handling with securesystemslib (#402, #408)
- Artifact recording exclude pattern documentation (#373, #405)
- Test key generation mixin (#402)
- 2021 roadmap document (#381)
- Move 'settings' docs to new 'configuration' section and make minor enhancements in structure and content (#405)
- Update tested dependencies (#377, #383, #384, #386, #389, #390, #394, #397, #398, #400, #404, #406, #409, #410, #411)
- Debian downstream release metadata (#382)
- 'util' crypto module in favor of securesystemslib key interfaces (#402)
- Obsolete coveralls.io API call in Travis test builds (#399)
- Minor docs issues (#396, #385, #395)
- pylint 2.6.0 (#387) and lgtm.com (#379) warnings
- Docs: Major CLI and API documentation overhaul and release (#341, #369)
- Bugfix: Use kwargs in in-toto-run to fix lstrip-paths bug (#340)
- Feature: Add option to specify target directory for generated metadata (#364)
- Tests: Add Python 3.8 to tested versions (#339)
- Tests: Add tmp dir and gpg key test mixins (#345)
- Tests: Use constant from securesystemslib to detect GPG in tests (#352)
- Tests: Enhance test suite feedback on Windows (#368)
- Dependencies: Misc updates (#342, #346, #349, #350, #353, #354, #356, #358, #359, #362, #363, #366)
- Drop custom OpenPGP subpackage and subprocess module and instead use the
ones provided by securesystemslib, which are based on the in-toto
implementation and receive continued support from a larger community (#325)
- A race condition that caused tests to sporadically fail was already fixed in securesystemslib and is now also available to in-toto (#282, secure-systems-lab/securesystemslib#186)
- Add Sphinx boilerplate and update installation instructions (#298, #331)
- Update misc dependencies (#317, #318, #319, #320, #322, #323, #324, #326, #327, #328, #333, #335, #329)
- Update downstream debian metadata (#311, #334)
- Update securesystemslib dependency to v0.12.0 (#299)
- Add
--version
option to CLI tools (#310) - Address linter warnings (#308)
- Update downstream debian metadata (#302, #305, #309)
- Add REQUIRE artifact rule support (#269, #280)
- Enhance OpenPGP key export and provide key expiration verification (#266, #288)
- Make transitive dependency PyNaCl optional for in-toto (#291)
- Improve automatic testing and code coverage measurement (#295) as well as static analysis with pylint (#279, #296)
- Update repository metadata
- Add initial 1-year roadmap (#268)
- Revise dependency handling for monitoring and library compatibility (#294)
- Update maintainers and contributor information (#283, #274, #297)
- Enhance source distribution configs and include tests and other metadata, relevant to downstream packagers, with future source distributions (#290)
- Re-factor rule verification engine and fix for a false-reject on very specific layouts (#262)
- Add support for duplicate standard streams (#252)
- Enhance support for Summary link naming (i.e., better sublayout verification, #256)
- Improve rule verification messages (#243)
- Small fixes for OpenPGP parsing functions (#255)
- Properly verify self-signature and signature binding signatures upon export (#257)
- Add lstrip-paths parameter (as an enhancement/replacement for basepath) (#250)
- Fix a bug where multiple PGP subkeys could count towards the threshold (#251)
- Fix a bug where RSA signatures wouldn't be sufficiently padded and a signature would be erroneously-rejected #170
- Change license to Apache
- Add common interface for Python's subprocess module
- Add Python 3.7 support
- Drop Python 3.3 support
- Add windows support
- Add AppVeyor testing (windows)
- Add optional line ending normalization when hashing artifacts (windows)
- Add optional compact json representation for metadata
- Make exclude filter behavior match gitignore when recording artifacts
- Make cwd recording optional when creating link metadata
- Add a substitution layer to support parameter substitution upon verification
- Improve gpg support
- Add full support for ed25519 keys and add optional key type parameter
- Fix bug in rule verification (in-toto#204)
- Add support for gpg signing subkeys.
- Drop strict requirement on securesystemslib 0.10.
- Command line tool changes:
- Add a --base-path parameter to in-toto record and in-toto run
- in-toto-record now follows symbolic links
- Fixed typo in exception messages
- Adds support for sublayout namespacing (for in-toto spec 0.9 compliance)
- Path prefix is normalized during in-toto verification:
- Paths such as foo//bar match with foo/bar.
- Dropped obsolete SettingsError
- Model changes
- Add metablock validators
- Add abstract class for layout steps and inspections
- Disallow passing command string to step and inspection constructor
- Add custom
__repr__
for step and inspection objects - Add layout creation convenience methods
- Command Line tool changes
- Add missing shebangs
- Enhance help messages
- Fix argparse bug for required subcommand in in-toto-record
- Rename short option to record streams in in-toto-run
- Fix gpg hashing algorithm name
- Add layout creation example document
- Refactor logging and user feedback
- Rename artifact_rules module to rulelib and add convenience methods
- Fix link metadata bug in in_toto_mock
- Add support for GPG signing and verification of layout and link metadata
- Add support for Python 3.4, 3.5 and 3.6
- Refactor signature and threshold verification in final product verification so that not every signature on a given layout needs to be valid, as long as every signature for which a key is passed is valid, and at least one key is passed. Furthermore, not all imported links need need to carry an authorized and valid signature, as as long as there are enough links with an authorized and valid signature for any given step. Links with unauthorized signatures or invalid signatures are ignored
- Remove canonicaljson dependency and use securesystemslib's canonicaljson encoding
- Refactor order of positional arguments in in-toto-record command line tool
- Add linters (pylint and bandit) and fix linting errors (e.g.: indentation and unused variables and imports)
- Add schemas for in-toto specific crypto-related metadata formats
- Improve testing code coverage to 100%
- Add debian directory required to create a debian package
- Add .editorconfig and GitHub issue and pull request templates, ACKNOWLEDGEMENTS.md, CODE-OF-CONDUCT.md, GOVERNANCE.md, MAINTAINERS.txt and passing core infrastructure best practice badge, add "Security Issues and Bugs" and "Instructions for Contributors" section in README.md
- Initial pre-release