diff options
Diffstat (limited to '')
-rw-r--r-- | cgitize/bitbucket.py | 16 | ||||
-rw-r--r-- | cgitize/repo.py | 12 |
2 files changed, 13 insertions, 15 deletions
diff --git a/cgitize/bitbucket.py b/cgitize/bitbucket.py index 052d2c1..f2a449f 100644 --- a/cgitize/bitbucket.py +++ b/cgitize/bitbucket.py @@ -17,21 +17,19 @@ class Bitbucket: def get_repo(self, repo): try: - return self._impl.repositories.get(repo.id) + parts = repo.id.split('/') + if len(parts) != 2: + raise ValueError(f'repository ID must be in the USER/NAME format: {repo.id}') + user, name = parts + return self._impl.repositories.get(user, name) except HTTPError: logging.error("Couldn't fetch repository: %s", repo.id) raise def get_user_repos(self, user): try: - page = 1 - while True: - params = {'page': page} - response = self._impl.repositories.get(user.name, params=params) - yield from iter(response['values']) - if 'next' not in response: - break - page += 1 + workspace = self._impl.workspaces.get(user.name) + yield from workspace.repositories.each() except HTTPError: logging.error("Couldn't fetch user repositories: %s", user.name) raise diff --git a/cgitize/repo.py b/cgitize/repo.py index dd55b17..2c9398e 100644 --- a/cgitize/repo.py +++ b/cgitize/repo.py @@ -41,18 +41,18 @@ class Repo: @staticmethod def from_bitbucket(src, config, subdir=None): - name = src['name'] - desc = src['description'] - homepage = src['links']['html']['href'] - owner = src['owner']['display_name'] + name = src.name + desc = src.description + homepage = src.get_link('html') + owner = src.data['owner']['display_name'] - https_urls = [link for link in src['links']['clone'] if link['name'] == 'https'] + https_urls = [link for link in src.data['links']['clone'] if link['name'] == 'https'] if len(https_urls) != 1: raise RuntimeError(f"no https:// clone URL for repository '{name}'?!") # Bitbucket leaves the username in the URL... Sigh. https_url = url_remove_auth(https_urls[0]['href']) - ssh_urls = [link for link in src['links']['clone'] if link ['name'] == 'ssh'] + ssh_urls = [link for link in src.data['links']['clone'] if link ['name'] == 'ssh'] if len(ssh_urls) != 1: raise RuntimeError(f"no ssh:// clone URL for repository '{name}'?!") ssh_url = ssh_urls[0]['href'] |