Skip to content

Commit

Permalink
Add support for Replicate feature
Browse files Browse the repository at this point in the history
Pulp Container now supports the Replication feature.

Also, Distribution now reports whether the registry is using HTTP (unsecure) or HTTPS (secure)
via the new 'secure' field inside ContainerDistributionSerializer.

closes #1648
closes #1213
  • Loading branch information
MichalPysik committed Jun 7, 2024
1 parent 7cab423 commit 49a0099
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 0 deletions.
2 changes: 2 additions & 0 deletions CHANGES/1213.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
Distribution now reports whether the registry is using HTTP (insecure) or HTTPS (secure) via the
new 'secure' field.
1 change: 1 addition & 0 deletions CHANGES/1648.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Pulp Container now supports the Replication feature.
56 changes: 56 additions & 0 deletions pulp_container/app/replica.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
from pulpcore.plugin.replica import Replicator
from pulpcore.plugin.util import get_url

from pulp_glue.container.context import (
PulpContainerDistributionContext,
PulpContainerRepositoryContext,
)

from pulp_container.app.models import ContainerDistribution, ContainerRemote, ContainerRepository
from pulp_container.app.tasks import synchronize as container_synchronize


class ContainerReplicator(Replicator):
distribution_ctx_cls = PulpContainerDistributionContext
repository_ctx_cls = PulpContainerRepositoryContext
publication_ctx_cls = None
remote_model_cls = ContainerRemote
repository_model_cls = ContainerRepository
distribution_model_cls = ContainerDistribution
distribution_serializer_name = "ContainerDistributionSerializer"
repository_serializer_name = "ContainerRepositorySerializer"
remote_serializer_name = "ContainerRemoteSerializer"
app_label = "container"
sync_task = container_synchronize

def sync_params(self, repository, remote):
"""Returns a dictionary where key is a parameter for the sync task."""
return dict(
remote_pk=str(remote.pk),
repository_pk=str(repository.pk),
signed_only=False, # TODO not sure
mirror=True,
)

def url(self, upstream_distribution):
if upstream_distribution["secure"]:
prefix = "https://"
else:
prefix = "http://"
return prefix + upstream_distribution["registry_path"].split("/")[0]

def remote_extra_fields(self, upstream_distribution):
upstream_name = upstream_distribution["registry_path"].split("/")[1]
return {"upstream_name": upstream_name}

def distribution_data(self, repository, upstream_distribution):
"""
Return the fields that need to be updated/cleared on distributions for idempotence.
"""
return {
"repository": get_url(repository),
"base_path": upstream_distribution["base_path"],
}


REPLICATION_ORDER = [ContainerReplicator]
8 changes: 8 additions & 0 deletions pulp_container/app/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -351,6 +351,13 @@ class ContainerDistributionSerializer(DistributionSerializer, GetOrCreateSeriali
view_name_pattern=r"remotes(-.*/.*)?-detail",
read_only=True,
)
secure = serializers.SerializerMethodField(
help_text="Whether the distribution is served over HTTP (insecure) or HTTPS (secure)."
)

def get_secure(self, obj):
request = self.context["request"]
return request.is_secure()

def validate(self, data):
"""
Expand Down Expand Up @@ -406,6 +413,7 @@ class Meta:
"namespace",
"private",
"description",
"secure",
)


Expand Down

0 comments on commit 49a0099

Please sign in to comment.