Skip to content

Commit

Permalink
Fleshed out rpm-content ttypes.
Browse files Browse the repository at this point in the history
closes pulp#505.
  • Loading branch information
ggainey committed May 16, 2022
1 parent 51798c7 commit f53bd7c
Show file tree
Hide file tree
Showing 3 changed files with 261 additions and 43 deletions.
1 change: 1 addition & 0 deletions CHANGES/505.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Extended "rpm content" to cover all of the RPM content-types.
240 changes: 197 additions & 43 deletions pulpcore/cli/rpm/content.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from typing import IO, Optional, Union
from typing import IO, Optional, Union, Any

import click

Expand All @@ -15,10 +15,23 @@
list_command,
pulp_group,
show_command,
pulp_option,
type_option,
)
from pulpcore.cli.common.i18n import get_translation
from pulpcore.cli.core.context import PulpArtifactContext
from pulpcore.cli.rpm.context import PulpRpmPackageContext
from pulpcore.cli.rpm.context import (
PulpRpmPackageContext,
PulpRpmAdvisoryContext,
PulpRpmDistributionTreeContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
PulpRpmPackageCategoryContext,
PulpRpmPackageEnvironmentContext,
PulpRpmPackageGroupContext,
PulpRpmPackageLangpacksContext,
PulpRpmRepoMetadataFileContext,
)

translation = get_translation(__name__)
_ = translation.gettext
Expand Down Expand Up @@ -52,74 +65,215 @@ def _sha256_artifact_callback(


@pulp_group()
@click.option(
"-t",
"--type",
"content_type",
type=click.Choice(["package"], case_sensitive=False),
@type_option(
choices={
"package": PulpRpmPackageContext,
"advisory": PulpRpmAdvisoryContext,
"distribution_tree": PulpRpmDistributionTreeContext,
"modulemd_defaults": PulpRpmModulemdDefaultsContext,
"modulemd": PulpRpmModulemdContext,
"package_category": PulpRpmPackageCategoryContext,
"package_environment": PulpRpmPackageEnvironmentContext,
"package_group": PulpRpmPackageGroupContext,
"package_langpack": PulpRpmPackageLangpacksContext,
"repo_metadata_file": PulpRpmRepoMetadataFileContext,
},
default="package",
case_sensitive=False,
)
@pass_pulp_context
@click.pass_context
def content(ctx: click.Context, pulp_ctx: PulpContext, content_type: str) -> None:
if content_type == "package":
ctx.obj = PulpRpmPackageContext(pulp_ctx)
else:
raise NotImplementedError()
def content(ctx: click.Context, pulp_ctx: PulpContext) -> None:
pass


list_options = [
click.option("--arch"),
click.option("--arch-in", "arch__in"),
click.option("--epoch"),
click.option("--epoch-in", "epoch__in"),
click.option("--fields"),
click.option("--name"),
click.option("--name-in", "name__in"),
click.option("--package-href"),
click.option("--release"),
click.option("--release-in", "release__in"),
click.option("--repository-version"),
click.option("--version"),
click.option("--version-in", "version__in"),
pulp_option("--exclude_fields"),
pulp_option("--fields"),
pulp_option("--repository-version"),
pulp_option("--arch", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--arch-in", "arch__in", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--arch-ne", "arch__ne", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--epoch", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--epoch-in", "epoch__in", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--epoch-ne", "epoch__ne", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--id", allowed_with_contexts=(PulpRpmPackageContext, PulpRpmAdvisoryContext)),
pulp_option(
"--id-in", "id__in", allowed_with_contexts=(PulpRpmPackageContext, PulpRpmAdvisoryContext)
),
pulp_option("--module", allowed_with_contexts=(PulpRpmModulemdDefaultsContext,)),
pulp_option("--module-in", "module__in", allowed_with_contexts=(PulpRpmModulemdDefaultsContext,)),
pulp_option("--name", allowed_with_contexts=(PulpRpmPackageContext, PulpRpmModulemdContext)),
pulp_option(
"--name-in",
"name__in",
allowed_with_contexts=(PulpRpmPackageContext, PulpRpmModulemdContext),
),
pulp_option(
"--name-ne",
"name__ne",
allowed_with_contexts=(PulpRpmPackageContext, PulpRpmModulemdContext),
),
pulp_option("--package-href", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--pkgId", allowed_with_contexts=(PulpRpmPackageContext, PulpRpmModulemdContext)),
pulp_option(
"--pkgId-in",
"pkgId__in",
allowed_with_contexts=(PulpRpmPackageContext, PulpRpmModulemdContext),
),
pulp_option("--release", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--release-in", "release__in", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--release-ne", "release__ne", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--severity", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--severity-in", "severity__in", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--severity-ne", "severity__ne", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option(
"--sha256",
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
),
pulp_option("--status", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--status-in", "status__in", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--status-ne", "status__ne", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option(
"--stream", allowed_with_contexts=(PulpRpmModulemdDefaultsContext, PulpRpmModulemdContext)
),
pulp_option(
"--stream-in",
"stream__in",
allowed_with_contexts=(PulpRpmModulemdDefaultsContext, PulpRpmModulemdContext),
),
pulp_option("--type", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--type-in", "type__in", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--type-ne", "type__ne", allowed_with_contexts=(PulpRpmAdvisoryContext,)),
pulp_option("--version", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--version-in", "version__in", allowed_with_contexts=(PulpRpmPackageContext,)),
pulp_option("--version-ne", "version__ne", allowed_with_contexts=(PulpRpmPackageContext,)),
]
lookup_options = [
href_option,
click.option("--relative-path", callback=_relative_path_callback, expose_value=False),
click.option("--sha256", callback=_sha256_callback, expose_value=False),
pulp_option(
"--relative-path",
callback=_relative_path_callback,
expose_value=False,
allowed_with_contexts=(PulpRpmPackageContext,),
),
pulp_option(
"--sha256",
callback=_sha256_callback,
expose_value=False,
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
),
]
# create works for modulemd_default/modulemd/package only
# create assumes "there exists an Artifact..."
create_options = [
click.option("--relative-path", required=True),
click.option(
pulp_option(
"--relative-path",
required=True,
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
),
pulp_option(
"--sha256",
"artifact",
required=True,
help=_("Digest of the artifact to use"),
callback=_sha256_artifact_callback,
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
),
]


content.add_command(list_command(decorators=list_options))
content.add_command(show_command(decorators=lookup_options))
content.add_command(create_command(decorators=create_options))
content.add_command(
create_command(
decorators=create_options,
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
)
)


@content.command()
@click.option("--relative-path", required=True)
@click.option("--file", type=click.File("rb"), required=True)
# upload works for advisory/modulemd_default/modulemd/package
# upload takes a file-argument and uploads to pulp, creates the artifact,
# then creates the entity from it
@content.command(
allowed_with_contexts=(
PulpRpmAdvisoryContext,
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
)
)
@chunk_size_option
@pass_entity_context
@pulp_option(
"--relative-path",
required=True,
help=_("Relative path within a distribution of the entity"),
allowed_with_contexts=(
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
),
)
@pulp_option(
"--file",
type=click.File("rb"),
required=True,
help=_("An RPM binary"),
allowed_with_contexts=(PulpRpmPackageContext,),
)
@pulp_option(
"--file",
type=click.File("rb"),
required=True,
help=_("A modulemd/defaults JSON file"),
allowed_with_contexts=(PulpRpmModulemdDefaultsContext, PulpRpmModulemdContext),
)
@pulp_option(
"--file",
type=click.File("rb"),
required=True,
help=_("An advisory JSON file"),
allowed_with_contexts=(PulpRpmAdvisoryContext,),
)
@pass_pulp_context
@pass_entity_context
def upload(
pulp_ctx: PulpContext,
entity_ctx: PulpRpmPackageContext,
relative_path: str,
file: IO[bytes],
chunk_size: int,
entity_ctx: Union[
PulpRpmAdvisoryContext,
PulpRpmPackageContext,
PulpRpmModulemdDefaultsContext,
PulpRpmModulemdContext,
],
**kwargs
) -> None:
"""Create an rpm package content unit by uploading a file"""
artifact_href = PulpArtifactContext(pulp_ctx).upload(file, chunk_size)
content = {"relative_path": relative_path, "artifact": artifact_href}
result = entity_ctx.create(body=content)
"""Create an rpm content unit by uploading a file"""
file = kwargs.pop("file")
chunk_size = kwargs.pop("chunk_size")
artifact_ctx = PulpArtifactContext(pulp_ctx)

artifact_href = artifact_ctx.upload(file, chunk_size)
body = {"artifact": artifact_href}
body.update(kwargs)
result = entity_ctx.create(body=body)
pulp_ctx.output_result(result)
63 changes: 63 additions & 0 deletions pulpcore/cli/rpm/context.py
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,69 @@ class PulpRpmPackageContext(PulpContentContext):
ID_PREFIX = "content_rpm_packages"


class PulpRpmAdvisoryContext(PulpContentContext):
ENTITY = "rpm advisory"
ENTITIES = "rpm advisories"
HREF = "rpm_update_record_href"
ID_PREFIX = "content_rpm_advisories"


class PulpRpmDistributionTreeContext(PulpContentContext):
ENTITY = "rpm distribution tree"
ENTITIES = "rpm distribution trees"
HREF = "rpm_distribution_tree_href"
ID_PREFIX = "content_rpm_distribution_trees"


class PulpRpmModulemdDefaultsContext(PulpContentContext):
ENTITY = "rpm modulemd defaults"
ENTITIES = "rpm modulemd defaults"
HREF = "rpm_modulemd_defaults_href"
ID_PREFIX = "content_rpm_modulemd_defaults"


class PulpRpmModulemdContext(PulpContentContext):
ENTITY = "rpm modulemd"
ENTITIES = "rpm modulemds"
HREF = "rpm_modulemd_href"
ID_PREFIX = "content_rpm_modulemds"


class PulpRpmPackageCategoryContext(PulpContentContext):
ENTITY = "rpm package category"
ENTITIES = "rpm package categories"
HREF = "rpm_package_category_href"
ID_PREFIX = "content_rpm_packagecategories"


class PulpRpmPackageEnvironmentContext(PulpContentContext):
ENTITY = "rpm package environment"
ENTITIES = "rpm package environments"
HREF = "rpm_package_environment_href"
ID_PREFIX = "content_rpm_packageenvironments"


class PulpRpmPackageGroupContext(PulpContentContext):
ENTITY = "rpm package group"
ENTITIES = "rpm package groups"
HREF = "rpm_package_group_href"
ID_PREFIX = "content_rpm_packagegroups"


class PulpRpmPackageLangpacksContext(PulpContentContext):
ENTITY = "rpm package langpack"
ENTITIES = "rpm package langpacks"
HREF = "rpm_package_langpacks_href"
ID_PREFIX = "content_rpm_packagelangpacks"


class PulpRpmRepoMetadataFileContext(PulpContentContext):
ENTITY = "rpm repo metadata file"
ENTITIES = "rpm repo metadata files"
HREF = "rpm_repo_metadata_file_href"
ID_PREFIX = "content_rpm_repo_metadata_files"


class PulpRpmPublicationContext(PulpEntityContext):
ENTITY = _("rpm publication")
ENTITIES = _("rpm publications")
Expand Down

0 comments on commit f53bd7c

Please sign in to comment.