- The
build_image
endpoint has been refactored to acceptbuild_context
(i.e., a file repository version) instead of raw artifacts. The same applies to Containerfile." #479 - Introduced the
type
field on the Manifests endpoint to enable easier differentiation of image types. #1751 - Added
architecture
,os
, andcompressed_image_size
fields to Manifest. #1767
- Resolved an issue with the pull-through cache that was causing errors when retrieving v2 schema 1 manifests. #1700
- Fixed an issue causing an HTTP 500 error when a GET request for a non-existing
blob was made to a distribution with only a
repository_version
set. #1703 - Fixed an HTTP 500 error returned when pushing an image with the same name as the name of an existing read-only repository. #1712
- Resolved an issue with syncing content causing errors when retrieving manifests without a mediaType definition. #1746
- Resolved an issue where syncing filtered content with a
cosign
signature from a remote source lackingSigstore
, and withsigned_only: true
enabled, could occasionally fail. #1759 - Fixed the JSONField specification so it doesn't break ruby bindings. See context here.
No significant changes.
- Fixed an issue causing an HTTP 500 error when a GET request for a non-existing
blob was made to a distribution with only a
repository_version
set. #1703 - Fixed the JSONField specification so it doesn't break ruby bindings. See context here.
- Added support for filtering remote repositories in pull-through caching using
includes
andexcludes
fields. These fields can be set on pull-through caching remote objects. #459 - Added support for the Replication feature. The replication process allows a Pulp instance to replicate container repositories from an upstream Pulp, creating the required remotes, repositories (those will always be read-only), and distributions. #1648
- The pulp signing task that produces atomic type signature no longer signs cosign signatures, attestations and sboms (images that end with .sig, .att, or .sbom), and ignores them instead. #1347
- Fixed a bug that caused intermittent failures during the pull-through caching when using non-local filesystem storage. #1493
- Made the pull-through caching machinery resilient to connection errors. #1499
- Pulp Container specific settings are now properly validated during the deployment checks of a Pulp instance. #1550
- Tasks created after uploading manifests will now remain available for further inspection and will not be deleted. #1602
- Disallowed anonymous users to pull images from private pull-through distributions. #1623
- Permitted users with the
pull_new_containerdistribution
permission to pull new data via pull-through distributions. #1624 - Modified the
_catalog
endpoint to allow non-authed users to see all repos in catalog (private and public) when token-auth is disabled. #1651 - Disallowed anonymous users to pull new content via a pull-through caching distribution. Content that is already cached/downloaded can be still pulled. #1657
- Fixed a bug where the authentication scheme in the authorization header was not being parsed correctly. #1812
- Fixed an issue in
DOCKER_MANIFEST_V1_SCHEMA
definition where the optionaljwk
header parameter was defined as required. #1874
- Fixed the JSONField specification so it doesn't break ruby bindings. See context here.
- Resolved an issue with syncing content causing errors when retrieving manifests without a mediaType definition. #1746
No significant changes.
- Fixed an issue causing an HTTP 500 error when a GET request for a non-existing
blob was made to a distribution with only a
repository_version
set. #1703
- Updated the Manifest model to no longer rely on artifacts, storing all manifest data internally within the database. This change dissociates the manifest from external files on the storage backend. #1288
- Resolved circular import errors raised when using pulp-container as a library. #1561
- Fixed hande-image-data command to skip content that has labels/annotations already populated. #1573
- Fixed handle-image-data command to update all entries in one run. #1575
- Fixed a bug that disallowed users from leveraging the remote authentication. #1577
- Fixed a bug that caused the registry to not accept requests from anonymous users when token authentication was disabled. #1605
- Removed the deprecated ADDITIONAL_OCI_ARTIFACT_TYPES setting. #1537
- Added
application/vnd.docker.distribution.manifest.v1+prettyjws
to the list of accepted media types retrieved from a remote registry. #1444 - Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Fixed a bug that disallowed users from leveraging the remote authentication. #1577
- Fixed a bug that caused the registry to not accept requests from anonymous users when token authentication was disabled. #1605
- Fixed the long accept header limit exceed during sync. #1696
- Fixed a bug where the authentication scheme in the authorization header was not being parsed correctly. #1812
- Fixed an issue in
DOCKER_MANIFEST_V1_SCHEMA
definition where the optionaljwk
header parameter was defined as required. #1874
- Fixed hande-image-data command to skip content that has labels/annotations already populated. #1573
- Fixed handle-image-data command to update all entries in one run. #1575
- Fixed a bug that disallowed users from leveraging the remote authentication. #1577
No significant changes.
- Resolved circular import errors raised when using pulp-container as a library. #1561
- Incorporated a notion of container images' characteristics. Users can now filter manifests by their
nature using the
is_flatpak
oris_bootable
field on the corresponding Manifest endpoint. In addition to that, manifest's annotations and configuration labels were exposed on the same endpoint too. #1437 - Updated the OCI manifest schema validation to comply with the changes from the OCI Image Manifest Specification. #1494
- Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Migrated the whole documentation to staging. The documentation should be now consumed from the unified docs site. #1517
- Removed the optional "kid" parameter stored inside the signatures' payload generated during
docker manifest v2 schema 1 conversion. This change also removes the
ecdsa
dependency, which is vulnerable to Minevra timing attacks. #1485 - Removed the manifest schema conversion machinery. If the manifest is stored locally in the newer format and old clients request v2 schema1 manifest they will receive 404. v2 schema1 manifest is still going to be mirrored from remote source during sync if available and passed to the old clients on the request. #1509
- Deprecated
ADDITIONAL_OCI_ARTIFACT_TYPES
setting in favour of the relaxed validation. #1494
- Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Added support for pull-through caching. Users can now configure a dedicated distribution and remote linked to an external registry without the need to create and mirror repositories in advance. Pulp downloads missing content automatically if requested and acts as a caching proxy. #507
- Added
application/vnd.docker.distribution.manifest.v1+prettyjws
to the list of accepted media types retrieved from a remote registry. #1444
- Started signing manifests asynchronously. This feature improves the performance of signing tasks.
Additionally, setting
MAX_PARALLEL_SIGNING_TASKS
was introduced to cap the number of threads used for parallel signing (defaults to10
). #1208 - Adjusted default access policies for new labels API. #1384
- Made pulp_container compatible with pulpcore 3.40. #1399
- Fixed re-sync failures after reclaiming disk space. #1400
- Fixed an issue in
DOCKER_MANIFEST_V1_SCHEMA
definition where the optionaljwk
header parameter was defined as required. #1874
- Fixed the long accept header limit exceed during sync. #1696
- Fixed a bug that disallowed users from leveraging the remote authentication. #1577
- Fixed a bug that caused the registry to not accept requests from anonymous users when token authentication was disabled. #1605
No significant changes.
- Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Removed the optional "kid" parameter stored inside the signatures' payload generated during
docker manifest v2 schema 1 conversion. This change also removes the
ecdsa
dependency, which is vulnerable to Minevra timing attacks. #1485
- Fixed re-sync failures after reclaiming disk space. #1400
- Added
application/vnd.docker.distribution.manifest.v1+prettyjws
to the list of accepted media types retrieved from a remote registry. #1444
No significant changes.
No significant changes.
- Added OCI artifact support for Helm charts. #464
- Added support to serve cosign signatures, SBOMs, and attestations. #1165
- Added support to mirror cosign signatures, SBOMs and attestations. #1166
- Added suport to push cosign signatures, attestations or SBOMs to Pulp Registry. #1167
- Added support for monolithic upload. #1219
- Enabled Pulp registry to support by default some well-known OCI types. #1232
- Added
ADDITIONAL_OCI_ARTIFACT_TYPES
setting to make the list of supported OCI artifact types configurable. #1233 - Added support for Flatpak index endpoints. #1315
- Taught the Container Registry to accept docker schema2 sub-manifest types in OCI index. #1231
- Fixed a security issue that allowed users without sufficient permissions to mount blobs. #1286
- Ensured downloader during the repair task contains accept headers for the manifests to download. #1303
- Disabled TLS validation, if opted out in a remote, when syncing signatures. #1305
- Fixed pulp-to-pulp failing sync with
406 Not Acceptable
. #1329
- Took the import/export feature out of tech preview. #1236
- Fixed a bug where the authentication scheme in the authorization header was not being parsed correctly. #1812
- Fixed an issue in
DOCKER_MANIFEST_V1_SCHEMA
definition where the optionaljwk
header parameter was defined as required. #1874
- Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Removed the optional "kid" parameter stored inside the signatures' payload generated during
docker manifest v2 schema 1 conversion. This change also removes the
ecdsa
dependency, which is vulnerable to Minevra timing attacks. #1485
- Taught the Container Registry to accept docker schema2 sub-manifest types in OCI index. #1231
- Fixed re-sync failures after reclaiming disk space. #1400
- Added
application/vnd.docker.distribution.manifest.v1+prettyjws
to the list of accepted media types retrieved from a remote registry. #1444
- Fixed a security issue that allowed users without sufficient permissions to mount blobs. #1286
- Fixed pulp-to-pulp failing sync with
406 Not Acceptable
. #1329
- Relaxed oci manifest json validation to allow other layer mediaTypes than oci layer type. #1227
- Ensured downloader during the repair task contains accept headers for the manifests to download. #1303
- Added support for automatically creating missing repositories during the import procedure. The
creation is disabled by default. Use
create_repositories=True
to tell Pulp to create missing repositories when executing the import procedure. #825 - Added a check if a manifest already exists locally to decrease the number of downloads from a remote registry when syncing content. #1047
- Enhanced push operation efficiency by implementing the utilization of ephemeral blobs and manifests, eliminating the need for generating unnecessary repository versions. #1212
- Updated compatibility for pulpcore 3.25 and Django 4.2. #1277
- Ensured an HTTP 401 response in case a user provides invalid credentials during the login
(e.g., via
podman login
). #918 - Translated v1 signed schema media_type into v1 schema instead. #1045
- Fixed content-disposition header which is used in the object storage backends. #1096
- Fixed an issue that caused all staff users to have superuser permissions when accessing the registry without token authentication enabled. #1109
- Fixed a bug where the Podman client could not verify manifest indices signed with a Pulp signing service. #1135
- Fixed a method for determining the media type of manifests when syncing content. #1147
- Added application/octet-stream as an accepted media_type for docker config objects. #1156
- Fixed signing task that could skip some image signing. #1209
- Started triggering only one mount-blob task per upload after back-off. #1211
- Started sanitizing input data when creating namespaces or distributions. #1229
- Fixed a bug that disallowed users to build images that have artifacts within the same directory. #1234
- Fixed a bug that disallowed users to configure custom authentication classes for the token server. #1254
- Fixed an issue in
DOCKER_MANIFEST_V1_SCHEMA
definition where the optionaljwk
header parameter was defined as required. #1874
No significant changes.
- Fixed the long accept header limit exceed during sync. #1696
No significant changes.
- Fixed sync failure due to ignored certs during registry signature extentions API check. #1552
- Removed the optional "kid" parameter stored inside the signatures' payload generated during
docker manifest v2 schema 1 conversion. This change also removes the
ecdsa
dependency, which is vulnerable to Minevra timing attacks. #1485
- Disabled TLS validation, if opted out in a remote, when syncing signatures. #1305
- Taught the Container Registry to accept docker schema2 sub-manifest types in OCI index. #1231
- Added
application/vnd.docker.distribution.manifest.v1+prettyjws
to the list of accepted media types retrieved from a remote registry. #1444
- Fixed re-sync failures after reclaiming disk space. #1400
- Fixed a security issue that allowed users without sufficient permissions to mount blobs. #1286
- Fixed pulp-to-pulp failing sync with
406 Not Acceptable
. #1329
- Ensured an HTTP 401 response in case a user provides invalid credentials during the login
(e.g., via
podman login
). #918 - Started triggering only one mount-blob task per upload after back-off. #1211
- Ensured downloader during the repair task contains accept headers for the manifests to download. #1303
- Fixed a bug that disallowed users to configure custom authentication classes for the token server. #1254
- Fixed signing task that could skip some image signing. #1209
- Relaxed oci manifest json validation to allow other layer mediaTypes than oci layer type. #1227
- Fixed a bug where the Podman client could not verify manifest indices signed with a Pulp signing service. #1135
- Fixed a method for determining the media type of manifests when syncing content. #1147
- Added application/octet-stream as an accepted media_type for docker config objects. #1156
No significant changes.
- Translated v1 signed schema media_type into v1 schema instead. #1045
- Added validation for uploaded and synced manifest JSON content. #672
- Silenced redundant logs when downloading signatures. #518
- Silenced redundant GnuPG errors logged while decrypting manifest signatures. #519
- Fixed a bug that caused untagged manifests to be tagged by their digest during the push operation. #852
- Fixed internal server errors raised when a podman client (<4.0) used invalid content types for manifest lists. #853
- Fixed a misleading error message raised when a user provided an invalid manifest list. #854
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883 - Started returning an HTTP 401 response in case of invalid credentials provided by a container
client (e.g.,
podman
). #918 - Configured aiohttp to avoid rewriting redirect URLs, as some web servers (e.g. Amazon CloudFront) can be tempermental about the encoding of the URL. #919
- Fixed the Content-Length key error raised when uploading images. #921
- Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
- Translated v1 signed schema media_type into v1 schema instead. #1045
- Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883 - Fixed the Content-Length key error raised when uploading images. #921
- Added support for streaming artifacts from object storage. #731
- Fixed the machinery for building OCI images. #461
- Fixed the regular expression for matching base paths in distributions. #756
- Fixed generation of the redirect url to the object storage #767
- Enforced the reference to manifests from tags. Note that this bugfix introduces a migration that removes tags without any reference to the manifests. #789
- Improved image upload process from podman/docker clients. These clients send data as one big chunk hence we don't need to save it as chunk but as an artifact directly. #797
- Fixed upload does not exist error during image push operation. #861
- Improved the documentation for RBAC by adding a new section for roles and a new section for migrating from permissions to roles. #641
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883 - Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
- Fixed upload does not exist error during image push operation. #861
- Added more robust validation for unknown fields passed via REST API requests. #475
- Added validation for signatures' payloads. #512
- Log messages are now not being translated. #690
- Fixed url of the registry root endpoint during signature source check. #646
- Fixed sync of signed content failing with the error [DeclarativeContent' object has no attribute 'd_content']{.title-ref}. #654
- Fixed group related creation hooks that failed if no current user could be identified. #673
- Fixed other instances of fd leak. #679
- Removed Namespace validation. Namespaces are managed transparently on behalf of the user. #688
- Fixed some tasks that were using /tmp/ instead of the worker working directory. #696
- Fixed the reference to a serializer for building images. #718
- Fixed the regular expression for matching dockerhub URLs. #736
- Added docs for client signature verification policy. #530
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883 - Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
- Fixed sync of signed content failing with the error [DeclarativeContent' object has no attribute 'd_content']{.title-ref}. #654
- Fixed group related creation hooks that failed if no current user could be identified. #673
- Fixed some tasks that were using /tmp/ instead of the worker working directory. #696
- Fixed upload does not exist error during image push operation. #861
- Allow upload of non-distributable layers. #462
- Added support for pushing manifest lists via the Registry API. #469
- Added support for cross repository blob mount. #494
- Added support for caching responses from the registry. The caching is not enabled by default.
Enable it by configuring the Redis connection and defining
CACHE_ENABLED = True
in the settings file. #496 - Added model, serializer, filter and viewset for image manifest signature. Added ability to sync manifest signatures from a sigstore. #498
- Added ability to sign container images from within The Pulp Registry. manifest_signing_service is used to produce signed container content. #500
- Added support for pushing image signatures to the Pulp Registry. The signatures can be pushed by utilizing the extensions API. #502
- Added an extensions API endpoint for downloading image signatures. #504
- Enabled users to import/export image signatures. #506
- Ported RBAC implementation to use pulpcore roles. #508
- Added recursive removal of manifest signatures when a manifest is removed from a repository. #511
- Added support for syncing signatures using docker API extension. #528
- Added ability to remove signatures from a container(push) repo. #548
- Don't reject manifest that has non-distributable layers during upload. #598
- Don't store blob's media_type on the model. There is no way to say what mimetype it has when it comes into the registry. #493
- Account for case when token's scope does not contain type/resource/action. #509
- Fixed content retrieval from distribution when repo is removed. #513
- Fixed file descriptor leak during image push. #523
- Fixed "manifest_id" violates not-null constraint error during sync. #537
- Fixed error during container image push. #542
- Return a more concise message exception on 500 during image pull when content is missing on the FS. #555
- Fixed a bug that disallowed users who were authenticated by a remote webserver to access the Registry API endpoints when token authentication was disabled. #558
- Successfully re-upload artifact in case it was previously removed. #595
- Fixed check for the signature source location. #617
- Accept token under access_token for compat reasons. #619
- Removed the optional "kid" parameter stored inside the signatures' payload generated during
docker manifest v2 schema 1 conversion. This change also removes the
ecdsa
dependency, which is vulnerable to Minevra timing attacks. #1485
- Fixed a method for determining the media type of manifests when syncing content. #1147
- Fixed container repo sync failure 'null value in column "image_manifest_id" violates not-null constraint'. #1190
- Fixed a database error raised when creating a distribution with a long base_path. #1103
- Translated v1 signed schema media_type into v1 schema instead. #1045
- Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
No significant changes.
No significant changes.
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883
- Fixed upload does not exist error during image push operation. #861
- Accept token under access_token for compat reasons. #619
- Fixed group related creation hooks that failed if no current user could be identified. #673
- Return a more concise message exception on 500 during image pull when content is missing on the FS. #555
- Successfully re-upload artifact in case it was previously removed. #595
- Fixed file descriptor leak during image push. #523
- Fixed "manifest_id" violates not-null constraint error during sync. #537
- Fixed error during container image push. #542
- Enabled Azure storage backend support. #9488
- Enabled rate_limit option on the remote. Rate limit defines N req/sec per connection. #9607
- Fixed a method for determining the media type of manifests when syncing content. #1147
- Fixed container repo sync failure 'null value in column "image_manifest_id" violates not-null constraint'. #1190
- Fixed a database error raised when creating a distribution with a long base_path. #1103
- Translated v1 signed schema media_type into v1 schema instead. #1045
- Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Introduced the
pulpcore-manager container-repair-media-type
command to fix incorrect media types of manifests that could have been stored in the database as a result of a sync task. #977
- Fixed an error that was raised when an OCI manifest did not contain
mediaType
. #883
- Accept token under access_token for compat reasons. #619
- Fixed upload does not exist error during image push operation. #861
- Return a more concise message exception on 500 during image pull when content is missing on the FS. #555
- Successfully re-upload artifact in case it was previously removed. #595
- Fixed file descriptor leak during image push. #523
- Fixed error during container image push. #542
- Fixed rate_limit option on the remote. Rate limit defines N req/sec per connection. #578
- Fixed a bug that caused container clients to be unable to interact with content stored on S3. #579
- Added validation for the supported manifests and blobs media_types in the push operation. #8303
- Fixed ORM calls in the content app that were made in async context to use sync_to_async. #9454
- Fixed a failure during distribution update that occured when unsetting repository_version. #9497
- Corrected value of
Content-Length
header for push upload responses. This fixes the upstream prematurely closed connection while reading upstream error that would appear in nginx logs after a push operation. #9516 - Fixed headers and status codes in the upload/blob responses during image push. #9568
- Send proper blob content_type header when the blob is served. #9571
- Fixed a bug that caused container clients to be unable to interact with content stored on S3. #9586
- Fixed a bug, where permissions were checked against the wrong object type. #9589
- Fixed ORM calls in the content app that were made in async context to use sync_to_async. (Backported from https://pulp.plan.io/issues/9454). #9538
- Corrected value of
Content-Length
header for push upload responses. This fixes the upstream prematurely closed connection while reading upstream error that would appear in nginx logs after a push operation (Backported from https://pulp.plan.io/issues/9516). #9539 - Fixed Azure storage backend support (Backported from https://pulp.plan.io/issues/9488). #9540
- Switched from
condition
element tocondition_expression
for boolean logic evaluation to support latest drf-access-policy. #9092 - Fix OpenAPI schema view #9258
- Refactor sync pipeline to fix a race condition with multiple synchronous syncs. #9292
- Added validation for a repository base path. #9403
- Fixed a bug that led Pulp to run out of DB connections during podman pull operations. #1146
- Fixed an HTTP 404 response during sync from registry.redhat.io. #974
- Accept token under access_token for compat reasons. #619
- Return a more concise message exception on 500 during image pull when content is missing on the FS. #555
- Successfully re-upload artifact in case it was previously removed. #595
- Fixed "manifest_id" violates not-null constraint error during sync. #537
- Fixed a bug that caused container clients to be unable to interact with content stored on S3. (Backported from https://pulp.plan.io/issues/9586). #9601
- Fixed rate_limit option on the remote which was ignored during the downloads. Rate limit defines N req/sec per connection ( backported from https://pulp.plan.io/issues/9610). #9610
- Corrected value of
Content-Length
header for push upload responses. This fixes the upstream prematurely closed connection while reading upstream error that would appear in nginx logs after a push operation (Backported from https://pulp.plan.io/issues/9516). #9521 - Fixed ORM calls in the content app that were made in async context to use loop.run_in_executor(). #9522
- Fixed Azure storage backend support (Backported from https://pulp.plan.io/issues/9488). #9523
- Added validation for a repository base path (Backported from https://pulp.plan.io/issues/9403). #9526
- Refactor sync pipeline to fix a race condition with multiple synchronous syncs. (backported from #9292) #9334
- Add model resources to allow pulp import export handle pulp_container content units for synced container repositories. #6636
- Enable reclaim disk space feature for blobs and manifests.This feature is available with pulpcore 3.15+ #9169
- Use proxy auth credentials when syncing content from a Remote. #9065
- Dropped support for Python 3.6 and 3.7. pulp_container now supports Python 3.8+. #9035
- Use proxy auth credentials when syncing content from a Remote. (backported from #9065) #9067
- As a user I can update container push repositories. #8313
- Updated distribution creation policy. #8244
- Improved error logging on failed image push. #8879
- Fixed access policy for the container repository
repair
endpoint. #8884
- Added ability for users to add a Remote to a Repository that is used by default when syncing. #7795
- Fixed a bug where image push of the same tag with docker client ended up in the different manifest upload. Updated Range header in the blob upload response so it is inclusive. #8543
- Add a fix to prevent server errors on push of new repositories including multiple layers. #8565
- Fixed apache snippet config and removed scheme #8573
- Do not suggest a time to wait on 429 responses. This allows clients to decide to play nice and increase backoff times. #8576
- Fix a bug where users with container.namespace_change_containerdistribution couldn't change distributions. #8618
- Fixed compution of the digest string during the manifest conversion so it also contains the algorithm. #8629
- Create and return empty_blob on the fly. #8631
- Fixed "connection already closed" error in the Registry handler. #8672
- Fixed broken links to API guide #8125
- Improved error logging on failed image push. (Backported from https://pulp.plan.io/issues/8879). #8888
- Fixed access policy for the container repository
repair
endpoint. (Backported from https://pulp.plan.io/issues/8884). #8889 - Fixed a bug that caused container clients to be unable to interact with content stored on S3. (Backported from https://pulp.plan.io/issues/9586). #9600
- Fixed "connection already closed" error in the Registry handler. (backported from #8672) #8697
- Fixed compution of the digest string during the manifest conversion so it also contains the algorithm. (backported from #8629) #8698
- Create and return empty_blob on the fly. (backported from #8631) #8699
- Do not suggest a time to wait on 429 responses. This allows clients to decide to play nice and increase backoff times (Backported from #8576). #8703
- Add a fix to prevent server errors on push of new repositories including multiple layers. (Backported from https://pulp.plan.io/issues/8565) #8591
- Fixed a bug where image push of the same tag with docker client ended up in the different manifest upload. Updated Range header in the blob upload response so it is inclusive. (Backported from https://pulp.plan.io/issues/8543) #8545
- Updated the catalog endpoint to show only repositories that users have permissions to pull from. #8068
- Config blob is downloaded always, regardless of the remote's settings. #8319
- Wrapped the repository version creation during blob upload commit in a task that will be waited on by issuing 429. #8151
- Released container RBAC from tech-preview. #8527
- Added pagination to the _catalog and the tags/list endpoint in the registry API. #7974
- Added a fall back to use BasicAuth if TOKEN_AUTH_DISABLED is set. #8074
- Added a new API endpoint that allows users to remove an image by a digest from a push repository. #8105
- Added a namespace_is_username helper to decide whether the namespace matches the username of the requests user. Changed the namespace access_policy to allow users without permissions to create the namespace that matches their username. #8197
- Fixed the
scope
field returned by the registry when a user was accessing the catalong endpoint without a token. In addition to that, the fieldaccess
returned by the token server for the root endpoint was fixed as well. #8045 - Added missing error code that should be returned in the WWW-Authenticate header. #8046
- Fixed a bug that caused the registry to fail during the schema conversion when there was not
provided the field
created_by
. #8299 - Prevent the registry pagination classes to fail if a negative page size is requested. #8318
- Use
get_user_model()
to prevent pulp_container from crashing when running alongside other pulp plugins that override the default user authentication models. #8260
- Added access policy and permission management to container repositories. #7706
- Added access policy and permission management to the container remotes. #7707
- Added access policy for ContainerDistributionViewSet and the Registry API. #7937
- Added access policy and permission management to the container namespaces. #7967
- Added RBAC to the push repository endpoint. #7968
- Add RBAC to the repository version endpoints. #8017
- Made the push and pull permission granting use the
ContainerDistribution
access policy. #8075 - Added Owner, Collaborator, and Consumer groups and permissions for Namespaces and Repositories. #8101
- Added a private flag to mark distributions global read accessability. #8102
- Added support for tagging and untagging manifests for push repositories. #8104
- Added RBAC for container content. #8142
- Made the token expiration time configurable via the setting 'TOKEN_EXPIRATION_TIME'. #8147
- Decoupled permissions for registry live api and pulp api. #8153
- Add description field to the ContainerDistribution. #8168
- Fixed a bug that caused the registry to advertise an invalid digest of a converted manifest. #7923
- Fixed the way how the plugin verifies authenticated users in the token authentication. #8057
- Adjusted the queryset filtering of
ContainerDistribution
to includeprivate
andNamespace
permissions. #8206 - Fixed bug experienced when pulling using docker 20.10 client. #8208
- POST and DELETE requests are no longer available for /pulp/api/v3/repositories/container/container-push/. Push repositories are still automatically created via docker/podman push and deleted through container distributions. #8014
- Fixed compution of the digest string during the manifest conversion so it also contains the algorithm. (Backported from https://pulp.plan.io/issues/8629). #8818
- Create and return empty_blob on the fly. (Backported from https://pulp.plan.io/issues/8654). #8819
- Fixed "connection already closed" error in the Registry handler. (Backported from https://pulp.plan.io/issues/8672). #8820
- Fixed a bug that caused the registry to fail during the schema conversion when there was not
provided the field
created_by
. (Backported from https://pulp.plan.io/issues/8299) #8349 - Fixed a bug that caused the registry to advertise an invalid digest of a converted manifest. (Backported from https://pulp.plan.io/issues/7923) #8350
- Fixed bug experienced when pulling using docker 20.10 client. (Backported from https://pulp.plan.io/issues/8208) #8367
- Added namespaces to group repositories and distributions. #7089
- Refactored the registry's push API to not store uploaded chunks in /var/lib/pulp, but rather in the shared storage. #7218
- Fixed the value of registry_path in a container distribution. #7385
- Added validation for tags' names. #7506
- Fixed Renderer to handle properly Manifest and Blob responses. #7620
- Updated models fields to not use settings directly. #7728
- Fixed a bug where Artifacts were missing sha224 checksum after podman push. #7774
- Updated scripts to correctly show the workflows. #7547
- Create and return empty_blob on the fly (Backported from https://pulp.plan.io/issues/8631) #8654
- Fixed compution of the digest string during the manifest conversion so it also contains the algorithm (Backported from https://pulp.plan.io/issues/8629). #8655
- Fixed "connection already closed" error in the Registry handler (Backported from https://pulp.plan.io/issues/8672). #8685
- Fixed Renderer to handle properly Manifest and Blob responses. (Backported from https://pulp.plan.io/issues/7620) #8346
- Fixed a bug that caused the registry to advertise an invalid digest of a converted manifest. (Backported from https://pulp.plan.io/issues/7923) #8347
- Fixed a bug that caused the registry to fail during the schema conversion when there was not
provided the field
created_by
. (Backported from https://pulp.plan.io/issues/8299) #8348 - Fixed bug experienced when pulling using docker 20.10 client. (Backported from https://pulp.plan.io/issues/8208) #8366
- Fixed the unnecessary double redirect issued for the S3 storage #6826
- Documented how include/exclude_tags options work with mirror=True/False. #7380
- Fixed bug where users would get 403 response when pulling from the registry running behind an HTTPS reverse proxy. #7462
- Added 'exclude_tags' to support e.g. skipping source containers in sync. #6922
- Push repositories will be deleted together with their attached distribution. #7172
- Updated the sync machinery to not store an image manifest as a tag's artifact #6816
- Added a validation, that a push repository cannot be distributed by specifying a version. #7012
- Forbid the REST API methods PATCH and PUT to prevent changes to repositories created via docker/podman push requests #7013
- Fixed the rendering of errors in the container registry api. #7054
- Repaired broken registry with TOKEN_AUTH_DISABLED=True #7304
- Updated docs for 2.0 GA. #7317
- Renamed 'whitelist_tags' to 'include_tags'. #7070
- Redirected get on Manifest get to the content app to enable schema conversion. Repaired schema conversion to work with django-storage framework. #6824
- Added ContainerPushRepository type to back writeable container registries. #6825
- Added ContentRedirectContentGuard to redirect with preauthenticated urls to the content app. #6894
- Restricted push access to admin user. #6976
- Refactored token_authentication that now happens in pulpcore-api app #6894
- Fixed a crash when trying to access content with an unparseable token. #7124
- Fixed a runtime error which was triggered when a registry client sends an accept header with an inappropriate media type for a manifest and the conversion failed. #7125
- Fixed the client_max_body_size value in the nginx config. #6916
- Added REST APIs for handling docker/podman push. #5027
- Fixed 500 error when pulling by tag. #6776
- Ensure that all relations between content models are properly created #6827
- Auto create repos and distributions for the container push. #6878
- Fixed not being able to push tags with periods in them. #6884
- Improved the performance of the synchronization #6940
- Including requirements.txt on MANIFEST.in #6890
- Enable S3 as alternative storage. #4456
- Fixed webserver snippets config #6628
- Added a new section about using pull secrets #6315
- Added support for filtering tags using wildcards #6338
- Enable users to sync content in mirror mode #5771
- Provide apache and nginx config snippets to be used by the installer. #6292
- Building an image from a Containerfile no longer requires root access. #5895
- Let users fetch the list of all distributed repositories via the _catalog endpoint #5772
- Adds ability to build OCI images from Containerfiles. #5785
- The schema conversion cannot be applied for manifests with foreign layers #5646
- Adds operation_summaries for ContainerRepository operations #5956
- As a user, I can remove all repository container content with ["*"] #5756
- Enable users to disable the token authentication from the settings #5796
- As a user I can manage images in OCI format. #5816
- Allow users to provide fully qualified domain name of a token server with an associated port number #5779
- Add note about access permissions for private and public keys #5778
- No duplicated content can be present in a repository version. #3541
- Convert manifests of the format schema 2 to schema 1 #4244
- Add support for pulling content using token authentication #4938
- Store whitelisted tags in a list instead of CSV string #5515
- Make repositories "typed". Repositories now live at a detail endpoint. Sync is performed by POSTing to {repo_href}/sync/ remote={remote_href}. #5625
- Added v2s2 to v2s1 converter. #5635
- Fix using specified proxy for downloads. #5637
- Change the prefix of Pulp services from pulp-* to pulpcore-* #4554
-
Change _type to pulp_type #5454
-
Change _id, _created, _last_updated, _href to pulp_id, pulp_created, pulp_last_updated, pulp_href #5457
-
Remove "_" from _versions_href, _latest_version_href #5548
-
Removing base field: _type . #5550
-
Sync is no longer available at the {remote_href}/sync/ repository={repo_href} endpoint. Instead, use POST {repo_href}/sync/ remote={remote_href}.
Creating / listing / editing / deleting Container repositories is now performed on /pulp/api/v3/repositories/container/container/ instead of /pulp/api/v3/repositories/. Only Container content can be present in a Container repository, and only a Container repository can hold Container content. #5625
- Fix a bug that allowed arbitrary url prefixes for custom endpoints. #5486
- Add Docker-Distribution-API-Version header among response headers. #5527
- Add endpoint to recursively copy manifests from a source repository to a destination repository. #3403
- Add endpoint to recursively add docker content to a repository. #3405
- As a user I can sync from a docker repo published by Pulp2/Pulp3. #4737
- Add support for tagging and untagging manifests via an additional endpoint #4934
- Add endpoint for copying all tags from a source repository, or specific tags by name. #4947
- Add ability to filter Manifests and ManifestTags by media_type and digest #5033
- Add ability to filter Manifests, ManifestTags and Blobs by multiple media_types #5157
- Add endpoint to recursively remove docker content from a repository. #5179
- Allow Accept header to send multiple values. #5211
- Populate ManifestListManifest thru table during sync. #5235
- Fixed a problem where repeated syncs created invalid orphaned tags. #5252
- Add 'Docker-Content-Digest' header to the response headers. #4646
- Allow docker remote whitelist_tags to be unset to null. #5017
- Remove schema1 manifest signature when calculating its digest. #5037
- Switch to using towncrier for better release notes. #4875
- Add an example to the whitelist_tag help text #4994
- Add list of features to the docker landing page. #5030