Commit 0983db89 authored by Tim Lauridisen's avatar Tim Lauridisen

fixed reposync to work with the latest yum API (2.9.x)

parent 965f0147
......@@ -34,6 +34,8 @@
import os
import sys
sys.path.insert(0, '/usr/share/yum-cvs')
from optparse import OptionParser
from urlparse import urljoin
......@@ -44,6 +46,7 @@ from yum.constants import *
from yum.packages import parsePackages
from yum.packageSack import ListPackageSack
import rpmUtils.arch
import logging
# for yum 2.4.X compat
def sortPkgObj(pkg1 ,pkg2):
......@@ -58,13 +61,8 @@ def sortPkgObj(pkg1 ,pkg2):
class RepoSync(yum.YumBase):
def __init__(self, opts):
self.logger = logging.getLogger('yum.verbose.reposync')
self.opts = opts
def log(self, num, msg):
if num < 3 and not self.opts.quiet:
print msg
def parseArgs():
usage = """
......@@ -113,7 +111,7 @@ def main():
my = RepoSync(opts=opts)
my.doConfigSetup(fn=opts.config, init_plugins=False)
# do the happy tmpdir thing if we're not root
if os.geteuid() != 0 or opts.tempcache:
......@@ -168,7 +166,7 @@ def main():
str(os.path.getsize(local)) == pkg.returnSimple('packagesize')):
if not opts.quiet:
my.errorlog(0,"%s already exists and appears to be complete" % local)
my.logger.error("%s already exists and appears to be complete" % local)
if opts.urls:
......@@ -181,13 +179,16 @@ def main():
except IOError, e:
my.errorlog(0, "Could not make repo subdir: %s" % e)
my.logger.error("Could not make repo subdir: %s" % e)
# Disable cache otherwise things won't download
repo.cache = 0
my.log(2, 'Downloading %s' % os.path.basename(remote))
repo.get(relative=remote, local=local)
if not opts.quiet: 'Downloading %s' % os.path.basename(remote))
pkg.localpath = local # Hack: to set the localpath we want.
if __name__ == "__main__":
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment