Пример #1
0
    def __init__(  # noqa: D107
            self,
            base_url,
            username,
            password,
            task_timeout=60.0,
            task_polling_interval=0.5):
        self._task_timeout = task_timeout
        self._task_polling_interval = task_polling_interval

        self._config = pulpcore.Configuration(base_url,
                                              username=username,
                                              password=password)

        # https://pulp.plan.io/issues/5932
        self._config.safe_chars_for_path_param = '/'

        # Core APIs
        self._core_client = pulpcore.ApiClient(self._config)
        self._core_tasks_api = pulpcore.TasksApi(self._core_client)

        # RPM APIs
        self._rpm_client = pulp_rpm.ApiClient(self._config)
        self._rpm_distributions_api = pulp_rpm.DistributionsRpmApi(
            self._rpm_client)
        self._rpm_packages_api = pulp_rpm.ContentPackagesApi(self._rpm_client)
        self._rpm_publications_api = pulp_rpm.PublicationsRpmApi(
            self._rpm_client)
        self._rpm_remotes_api = pulp_rpm.RemotesRpmApi(self._rpm_client)
        self._rpm_repos_api = pulp_rpm.RepositoriesRpmApi(self._rpm_client)
Пример #2
0
def main(argv=sys.argv[1:]):
    parser = argparse.ArgumentParser(description='Upload package to pulp')
    parser.add_argument('package_file',
                        nargs='+',
                        metavar='FILE',
                        help='Package file paths to upload')
    add_argument_pulp_base_url(parser)
    add_argument_pulp_password(parser)
    add_argument_pulp_task_timeout(parser)
    add_argument_pulp_username(parser)
    add_argument_pulp_resource_record(parser)
    args = parser.parse_args(argv)

    with Scope('SUBSECTION', 'upload package(s) to pulp'):
        pulp_config = pulp_rpm.Configuration(args.pulp_base_url,
                                             username=args.pulp_username,
                                             password=args.pulp_password)

        # https://pulp.plan.io/issues/5932
        pulp_config.safe_chars_for_path_param = '/'

        pulp_rpm_client = pulp_rpm.ApiClient(pulp_config)
        pulp_packages_api = pulp_rpm.ContentPackagesApi(pulp_rpm_client)

        pulp_task_poller = PulpTaskPoller(pulp_config, args.pulp_task_timeout)

        created_resources = []

        for file_path in args.package_file:
            relative_path = os.path.basename(file_path)

            print("Uploading '%s' to '%s'." % (file_path, pulp_config.host))
            upload_task_href = pulp_packages_api.create(relative_path,
                                                        file=file_path).task
            upload_task = pulp_task_poller.wait_for_task(upload_task_href)

            created_rpm = pulp_packages_api.read(
                upload_task.created_resources[0])
            created_resources.append(created_rpm.pulp_href)

            print('Created RPM resource: %s%s' %
                  (pulp_config.host, created_rpm.pulp_href))
            print(
                "Package '%s' version: %s%s-%s" %
                (created_rpm.name,
                 (created_rpm.epoch + ':') if created_rpm.epoch != '0' else '',
                 created_rpm.version, created_rpm.release))

        if args.pulp_resource_record:
            print("Saving upload record to '%s'." % args.pulp_resource_record)
            with open(args.pulp_resource_record, 'w') as resource_record:
                resource_record.write('PULP_RESOURCES=%s\n' %
                                      ' '.join(created_resources))
Пример #3
0
def main(argv=sys.argv[1:]):
    parser = argparse.ArgumentParser(
        description='Import packages into a repository and publish it')
    parser.add_argument(
        'package_resources',
        nargs='*',
        metavar="PULP_HREF",
        help='Identifiers for packages which should be imported')
    add_argument_invalidate(parser)
    parser.add_argument(
        '--invalidate-expression',
        default=None,
        help=
        'Any existing package names matching this expression will be removed')
    add_argument_pulp_base_url(parser)
    add_argument_pulp_distribution_name(parser)
    add_argument_pulp_password(parser)
    add_argument_pulp_task_timeout(parser)
    add_argument_pulp_username(parser)
    args = parser.parse_args(argv)

    pulp_config = pulp_rpm.Configuration(args.pulp_base_url,
                                         username=args.pulp_username,
                                         password=args.pulp_password)

    # https://pulp.plan.io/issues/5932
    pulp_config.safe_chars_for_path_param = '/'

    pulp_rpm_client = pulp_rpm.ApiClient(pulp_config)
    pulp_packages_api = pulp_rpm.ContentPackagesApi(pulp_rpm_client)
    pulp_distributions_api = pulp_rpm.DistributionsRpmApi(pulp_rpm_client)
    pulp_publications_api = pulp_rpm.PublicationsRpmApi(pulp_rpm_client)
    pulp_repos_api = pulp_rpm.RepositoriesRpmApi(pulp_rpm_client)

    pulp_task_poller = PulpTaskPoller(pulp_config, args.pulp_task_timeout)

    with Scope('SUBSECTION', 'inspecting repository state'):
        distribution = pulp_distributions_api.list(
            name=args.pulp_distribution_name).results[0]
        print('Pulp Distribution: %s%s' %
              (pulp_config.host, distribution.pulp_href))

        old_publication = pulp_publications_api.read(distribution.publication)
        print('Pulp Repository: %s%s' %
              (pulp_config.host, old_publication.repository))
        print('Pulp Publication (current): %s%s' %
              (pulp_config.host, old_publication.pulp_href))
        print('Pulp Repository Version (current): %s%s' %
              (pulp_config.host, old_publication.repository_version))

        packages_in_version_page = pulp_packages_api.list(
            repository_version=old_publication.repository_version, limit=200)
        packages_in_version = list(packages_in_version_page.results)
        while packages_in_version_page.next:
            packages_in_version_page = pulp_packages_api.list(
                repository_version=old_publication.repository_version,
                limit=200,
                offset=len(packages_in_version))
            packages_in_version += packages_in_version_page.results

        assert packages_in_version_page.count == len(packages_in_version)
        print('Found %d packages in the repository' % len(packages_in_version))

        packages_to_add = {}
        packages_to_remove = {}

        # First, remove packages matching the explicit expression
        if args.invalidate_expression:
            compiled_expression = re.compile(args.invalidate_expression)
            for pkg in packages_in_version:
                if compiled_expression.match(pkg.name):
                    packages_to_remove[pkg.pulp_href] = pkg

        # Get the metadata for the packages we're adding
        for package_href in args.package_resources:
            package = pulp_packages_api.read(package_href)
            print('Importing package: %s-%s%s-%s.%s' %
                  (package.name,
                   (package.epoch + ':') if package.epoch != '0' else '',
                   package.version, package.release, package.arch))

            if package in packages_in_version:
                packages_to_remove.pop(package.pulp_href, None)
                print('Package is already present - skipping: %s%s' %
                      (pulp_config.host, package.pulp_href))
                continue

            packages_to_add[package.pulp_href] = package

    with Scope('SUBSECTION', 'determining which packages to invalidate'):
        # Remove any packages with the same name
        package_names = set([pkg.name for pkg in packages_to_add.values()])
        for pkg in packages_in_version:
            if pkg.name in package_names:
                packages_to_remove[pkg.pulp_href] = pkg

        package_provides = package_names.union(
            prov[0] for pkg in packages_to_add.values()
            for prov in pkg.provides)
        if args.invalidate:
            packages_to_remove.update(
                _get_recursive_dependencies(packages_in_version,
                                            package_provides))

    with Scope('SUBSECTION', 'committing changes'):
        print('Adding %d and removing %d from the repository' %
              (len(packages_to_add), len(packages_to_remove)))

        mod_data = pulp_rpm.RepositoryAddRemoveContent(
            add_content_units=list(packages_to_add.keys()),
            remove_content_units=list(packages_to_remove.keys()),
            base_version=old_publication.repository_version)

        print('Packages to add:\n- %s' % ('\n- '.join([
            pkg.location_href for pkg in packages_to_add.values()
        ]) if packages_to_add else '(none)'))
        print('Packages to remove:\n- %s' % ('\n- '.join([
            pkg.location_href for pkg in packages_to_remove.values()
        ]) if packages_to_remove else '(none)'))

        mod_task_href = pulp_repos_api.modify(old_publication.repository,
                                              mod_data).task
        mod_task = pulp_task_poller.wait_for_task(mod_task_href)

        try:
            print('Pulp Repository Version (new): %s%s' %
                  (pulp_config.host, mod_task.created_resources[0]))
        except IndexError:
            print('The given additions result in no changes to the repository')
            return 0

    with Scope('SUBSECTION', 'publishing changes'):
        publish_data = pulp_rpm.RpmRpmPublication(
            repository_version=mod_task.created_resources[0])

        publish_task_href = pulp_publications_api.create(publish_data).task
        publish_task = pulp_task_poller.wait_for_task(publish_task_href)

        print('Pulp Publication (new): %s%s' %
              (pulp_config.host, publish_task.created_resources[0]))

    with Scope('SUBSECTION', 'updating distribution'):
        distribution.publication = publish_task.created_resources[0]

        distribute_task_href = pulp_distributions_api.partial_update(
            distribution.pulp_href, distribution).task
        pulp_task_poller.wait_for_task(distribute_task_href)

        print('Finished - changes are live at %s/' % distribution.base_url)
Пример #4
0
def main(argv=sys.argv[1:]):
    parser = argparse.ArgumentParser(
        description=
        'List the pulp IDs of packages provided at a given pulp distribution endpoint'
    )
    add_argument_pulp_base_url(parser)
    add_argument_pulp_distribution_name(parser)
    add_argument_pulp_password(parser)
    add_argument_pulp_resource_record(parser)
    add_argument_pulp_task_timeout(parser)
    add_argument_pulp_username(parser)
    parser.add_argument(
        '--package-name-expression',
        default=None,
        help='Expression to match against packages in the repository')

    args = parser.parse_args(argv)

    pulp_config = pulp_rpm.Configuration(args.pulp_base_url,
                                         username=args.pulp_username,
                                         password=args.pulp_password)

    # https://pulp.plan.io/issues/5932
    pulp_config.safe_chars_for_path_param = '/'

    pulp_rpm_client = pulp_rpm.ApiClient(pulp_config)
    pulp_packages_api = pulp_rpm.ContentPackagesApi(pulp_rpm_client)
    pulp_distributions_api = pulp_rpm.DistributionsRpmApi(pulp_rpm_client)
    pulp_publications_api = pulp_rpm.PublicationsRpmApi(pulp_rpm_client)

    with Scope('SUBSECTION', 'list packages in the distribution'):
        distribution = pulp_distributions_api.list(
            name=args.pulp_distribution_name).results[0]
        print('Pulp Distribution: ' + pulp_config.host +
              distribution.pulp_href)

        publication = pulp_publications_api.read(distribution.publication)
        print('Pulp Publication: %s%s' %
              (pulp_config.host, publication.pulp_href))
        print('Pulp Repository: %s%s' %
              (pulp_config.host, publication.repository))
        print('Pulp Repository Version: %s%s' %
              (pulp_config.host, publication.repository_version))

        packages_in_version_page = pulp_packages_api.list(
            repository_version=publication.repository_version, limit=200)
        packages_in_version = list(packages_in_version_page.results)
        while packages_in_version_page.next:
            packages_in_version_page = pulp_packages_api.list(
                repository_version=publication.repository_version,
                limit=200,
                offset=len(packages_in_version))
            packages_in_version += packages_in_version_page.results

        print('Total packages in repository: %d' % len(packages_in_version))

        if args.package_name_expression:
            compiled_expression = re.compile(args.package_name_expression)
            packages_in_version = [
                pkg for pkg in packages_in_version
                if compiled_expression.match(pkg.name)
            ]

        print('Found %d packages:' % len(packages_in_version))
        for pkg in packages_in_version:
            print('- %s-%s%s-%s' %
                  (pkg.name, (pkg.epoch + ':') if pkg.epoch != '0' else '',
                   pkg.version, pkg.release))

        if args.pulp_resource_record:
            print("Saving pulp resource record to '%s'." %
                  args.pulp_resource_record)
            with open(args.pulp_resource_record, 'w') as resource_record:
                resource_record.write(
                    'PULP_RESOURCES=%s\n' %
                    (' '.join([pkg.pulp_href for pkg in packages_in_version])))