aboutsummaryrefslogtreecommitdiffstats
path: root/MgaRepo/GitHub.py
diff options
context:
space:
mode:
authorPapoteur <papoteur@mageialinux-online.org>2016-11-05 15:38:08 +0100
committerPapoteur <papoteur@mageialinux-online.org>2016-11-05 15:38:08 +0100
commitf372e877cb32a6c009e29ff9ddf1a14f8b2fd216 (patch)
treebe50c72a1a883aa07cad805d44a0cda906285997 /MgaRepo/GitHub.py
parent8f51e35c875c9cbb4637cbf8796ee66a871ba57f (diff)
downloadmgarepo-f372e877cb32a6c009e29ff9ddf1a14f8b2fd216.tar
mgarepo-f372e877cb32a6c009e29ff9ddf1a14f8b2fd216.tar.gz
mgarepo-f372e877cb32a6c009e29ff9ddf1a14f8b2fd216.tar.bz2
mgarepo-f372e877cb32a6c009e29ff9ddf1a14f8b2fd216.tar.xz
mgarepo-f372e877cb32a6c009e29ff9ddf1a14f8b2fd216.zip
Revert to 1.12.3 state
Diffstat (limited to 'MgaRepo/GitHub.py')
-rw-r--r--MgaRepo/GitHub.py90
1 files changed, 0 insertions, 90 deletions
diff --git a/MgaRepo/GitHub.py b/MgaRepo/GitHub.py
deleted file mode 100644
index 74da43e..0000000
--- a/MgaRepo/GitHub.py
+++ /dev/null
@@ -1,90 +0,0 @@
-from MgaRepo import Error, config
-from MgaRepo.rpmutil import get_pkg_tag, clone
-from MgaRepo.util import execcmd
-from MgaRepo import layout
-from MgaRepo.git import GIT
-from MgaRepo.svn import SVN
-from MgaRepo.vcsutil import detectVCS
-from rpm import RPMTAG_SUMMARY, RPMTAG_URL
-import github
-import os
-
-class GitHub(object):
- def __init__(self, username = config.get("github", "login"), password = config.get("github", "password")):
- self._github = github.Github(login_or_token=username, password=password)
- self._organization = self._github.get_organization(config.get("github", "organization", "mdkcauldron"))
- self._repos = self._organization.get_repos()
-
- def repository_exists(self, name):
- for repo in self._repos:
- if repo.name == name:
- return repo
- return None
-
- def create_repository(self, pkgname, **kwargs):
- repository = self._organization.create_repo(pkgname, **kwargs)
- return repository
-
- def delete_repository(self, pkgname, **kwargs):
- repository = self.repository_exists(pkgname)
- if repository:
- print("deleting repository %s" % repository.full_name)
- repository.delete()
- return True
- raise Error("repository %s doesn't exist!" % (self._organization.login+"/"+pkgname))
-
- def import_package(self, target):
- if not os.path.exists(target):
- target = layout.checkout_url(layout.package_url(target))
- vcs = detectVCS(target)
- top_dir = vcs.get_topdir()
- pkgname = layout.package_name(layout.remove_current(vcs.url))
-
- repository = self.repository_exists(pkgname)
- if not repository or not repository.get_stats_commit_activity():
- if not repository:
- if os.path.exists(vcs.path):
- summary = get_pkg_tag(RPMTAG_SUMMARY, path=top_dir)
- url = get_pkg_tag(RPMTAG_URL, path=top_dir)
- repository = self.create_repository(pkgname, description=summary, homepage=url)
- print("GitHub repository created at " + repository.html_url)
- else:
- print("Empty GitHub repository already created at %s, using" % repository.html_url)
-
- if isinstance(vcs, GIT):
- status, output = vcs.remote("add", repository.full_name, repository.ssh_url, noerror=True)
- if status:
- if status == 128 and ("fatal: remote %s already exists." % repository.full_name) \
- in output:
- pass
- else:
- raise Error(output)
-
- status, output = vcs.push("--mirror", repository.full_name, show=True)
- if status == 0:
- print("Success!")
- return True
- elif isinstance(vcs, SVN):
- clone(vcs.url, bindownload=False)
- return self.import_package(pkgname)
-
- else:
- raise Error("GitHub repository already exists at " + repository.html_url)
- raise Error("GitHub import failed...")
-
- def clone_repository(self, pkgname, target=None):
- if not target:
- target = pkgname
- repository = self.repository_exists(pkgname)
- if repository:
- svnurl = layout.checkout_url(layout.package_url(pkgname))
- if repository.permissions:
- giturl = repository.ssh_url
- else:
- giturl = repository.git_url
- execcmd(("git", "clone", "--mirror", giturl, os.path.join(target, ".git")), show=True)
- git_svn = GIT(path=target, url=svnurl)
- git_svn.init(svnurl, pkgname, branch="master", fullnames=True)
-
- return True
- raise Error("Repository %s doesn't exist!" % (self._organization.login+"/"+pkgname))