aboutsummaryrefslogtreecommitdiffstats
path: root/github3/models
diff options
context:
space:
mode:
Diffstat (limited to 'github3/models')
-rw-r--r--github3/models/__init__.py4
-rw-r--r--github3/models/base.py187
-rw-r--r--github3/models/gists.py49
-rw-r--r--github3/models/orgs.py28
-rw-r--r--github3/models/repos.py30
-rw-r--r--github3/models/user.py49
6 files changed, 202 insertions, 145 deletions
diff --git a/github3/models/__init__.py b/github3/models/__init__.py
index e69de29..6e4db1b 100644
--- a/github3/models/__init__.py
+++ b/github3/models/__init__.py
@@ -0,0 +1,4 @@
+from .user import AuthUser, User
+from .repos import Repo
+from .orgs import Org
+from .gists import Gist
diff --git a/github3/models/base.py b/github3/models/base.py
index 618e57f..1b1ce89 100644
--- a/github3/models/base.py
+++ b/github3/models/base.py
@@ -6,9 +6,9 @@ This module provides the Github3 object model.
"""
import json
+import inspect
-from .helpers import to_python, to_api, key_diff
-
+from github3.helpers import to_python, to_api, key_diff
class BaseResource(object):
"""A BaseResource object."""
@@ -18,15 +18,24 @@ class BaseResource(object):
_dates = []
_bools = []
_map = {}
+ _list_map = {}
_writeable = []
_cache = {}
+ def post_map(self):
+ try:
+ handler = self.handler()
+ methods = filter(lambda x: x[0].startswith('get') and callable(x),
+ inspect.getmembers(handler, inspect.ismethod))
+ for name, callback in methods:
+ setattr(self, method, callback)
+ except:
+ pass
def __init__(self):
self._bootstrap()
super(BaseResource, self).__init__()
-
def __dir__(self):
return self.keys()
@@ -56,6 +65,7 @@ class BaseResource(object):
date_keys = cls._dates,
bool_keys = cls._bools,
object_map = cls._map,
+ list_map = cls._list_map,
_gh = gh
)
@@ -70,109 +80,70 @@ class BaseResource(object):
return r
-class Plan(BaseResource):
- """Github Plan object model."""
-
- _strs = ['name']
- _ints = ['space', 'collaborators', 'private_repos']
-
- def __repr__(self):
- return '<plan {0}>'.format(str(self.name))
-
-class Org(BaseResource):
- """Github Organization object model."""
-
- _strs = [
- 'login', 'url', 'avatar_url', 'name', 'company', 'blog', 'location', 'email'
- 'html_url', 'type', 'billing_email']
- _ints = [
- 'id', 'public_repos', 'public_gists', 'followers', 'following',
- 'total_private_repos', 'owned_private_repos', 'private_gists', 'disk_usage',
- 'collaborators']
- _dates = ['created_at']
- _map = {'plan': Plan}
- _writable = ['billing_email', 'blog', 'company', 'email', 'location', 'name']
-
- @property
- def ri(self):
- return ('orgs', self.login)
-
- def __repr__(self):
- return '<org {0}>'.format(self.login)
-
- def repos(self, limit=None):
- return self._gh._get_resources(('orgs', self.login, 'repos'), Repo, limit=limit)
-
- def members(self, limit=None):
- return self._gh._get_resources(('orgs', self.login, 'members'), User, limit=limit)
-
- def is_member(self, username):
- if isinstance(username, User):
- username = username.login
-
- r = self._gh._http_resource('GET', ('orgs', self.login, 'members', username), check_status=False)
- return (r.status_code == 204)
-
- def publicize_member(self, username):
- if isinstance(username, User):
- username = username.login
-
- r = self._gh._http_resource('PUT', ('orgs', self.login, 'public_members', username), check_status=False, data='')
- return (r.status_code == 204)
-
- def conceal_member(self, username):
- if isinstance(username, User):
- username = username.login
-
- r = self._gh._http_resource('DELETE', ('orgs', self.login, 'public_members', username), check_status=False)
- return (r.status_code == 204)
-
- def remove_member(self, username):
- if isinstance(username, User):
- username = username.login
-
- r = self._gh._http_resource('DELETE', ('orgs', self.login, 'members', username), check_status=False)
- return (r.status_code == 204)
-
- def public_members(self, limit=None):
- return self._gh._get_resources(('orgs', self.login, 'public_members'), User, limit=limit)
-
- def is_public_member(self, username):
- if isinstance(username, User):
- username = username.login
-
- r = self._gh._http_resource('GET', ('orgs', self.login, 'public_members', username), check_status=False)
- return (r.status_code == 204)
-
-
-class Gist(BaseResource):
- _strs = ['url', 'description', 'html_url', 'git_pull_url', 'git_push_url']
- _ints = ['id', 'comments']
- _bools = ['public']
- _dates = ['created_at']
- _map = {'user': User} #TODO: file
-
- @property
- def ri(self):
- return ('users', self.user.login, self.id)
-
- def __repr__(self):
- return '<gist %s/%s>' % (self.user.login, self.description)
-
-class Repo(BaseResource):
- _strs = [
- 'url', 'html_url', 'clone_url', 'git_url', 'ssh_url', 'svn_url',
- 'name', 'description', 'homepage', 'language', 'master_branch']
- _bools = ['private', 'fork']
- _ints = ['forks', 'watchers', 'size',]
- _dates = ['pushed_at', 'created_at']
- _map = {'owner': User}
-
-
- @property
- def ri(self):
- return ('repos', self.owner.login, self.name)
- def __repr__(self):
- return '<repo {0}/{1}>'.format(self.owner.login, self.name)
- # owner
+#class Org(BaseResource):
+# """Github Organization object model."""
+#
+# _strs = [
+# 'login', 'url', 'avatar_url', 'name', 'company', 'blog', 'location', 'email'
+# 'html_url', 'type', 'billing_email']
+# _ints = [
+# 'id', 'public_repos', 'public_gists', 'followers', 'following',
+# 'total_private_repos', 'owned_private_repos', 'private_gists', 'disk_usage',
+# 'collaborators']
+# _dates = ['created_at']
+# _map = {'plan': Plan}
+# _writable = ['billing_email', 'blog', 'company', 'email', 'location', 'name']
+#
+# @property
+# def ri(self):
+# return ('orgs', self.login)
+#
+# def __repr__(self):
+# return '<org {0}>'.format(self.login)
+#
+# def repos(self, limit=None):
+# return self._gh._get_resources(('orgs', self.login, 'repos'), Repo, limit=limit)
+#
+# def members(self, limit=None):
+# return self._gh._get_resources(('orgs', self.login, 'members'), User, limit=limit)
+#
+# def is_member(self, username):
+# if isinstance(username, User):
+# username = username.login
+#
+# r = self._gh._http_resource('GET', ('orgs', self.login, 'members', username), check_status=False)
+# return (r.status_code == 204)
+#
+# def publicize_member(self, username):
+# if isinstance(username, User):
+# username = username.login
+#
+# r = self._gh._http_resource('PUT', ('orgs', self.login, 'public_members', username), check_status=False, data='')
+# return (r.status_code == 204)
+#
+# def conceal_member(self, username):
+# if isinstance(username, User):
+# username = username.login
+#
+# r = self._gh._http_resource('DELETE', ('orgs', self.login, 'public_members', username), check_status=False)
+# return (r.status_code == 204)
+#
+# def remove_member(self, username):
+# if isinstance(username, User):
+# username = username.login
+#
+# r = self._gh._http_resource('DELETE', ('orgs', self.login, 'members', username), check_status=False)
+# return (r.status_code == 204)
+#
+# def public_members(self, limit=None):
+# return self._gh._get_resources(('orgs', self.login, 'public_members'), User, limit=limit)
+#
+# def is_public_member(self, username):
+# if isinstance(username, User):
+# username = username.login
+#
+# r = self._gh._http_resource('GET', ('orgs', self.login, 'public_members', username), check_status=False)
+# return (r.status_code == 204)
+#
+#
diff --git a/github3/models/gists.py b/github3/models/gists.py
new file mode 100644
index 0000000..5ad61c3
--- /dev/null
+++ b/github3/models/gists.py
@@ -0,0 +1,49 @@
+#!/usr/bin/env python
+# -*- encoding: utf-8 -*-
+#
+# author: David Medina
+
+from .base import BaseResource
+from .user import User
+
+class File(BaseResource):
+ _strs = ['filename', 'raw_url', 'content', 'language', 'type']
+ _ints = ['size']
+
+ def __repr__(self):
+ return '<File gist> %s' % self.filename
+
+class GistFork(BaseResource):
+ _strs = ['url']
+ _dates = ['created_at']
+ _map = {'user': User}
+
+ def __repr__(self):
+ return '<Gist fork> %s>' % self.user.login
+
+class ChangeStatus(BaseResource):
+ _ints = ['deletions', 'additions', 'total']
+
+ def __repr__(self):
+ return '<Gist history> change_status>'
+
+class GistHistory(BaseResource):
+ _strs = ['url', 'version']
+ _map = {'user': User, 'change_status': ChangeStatus}
+ _dates = ['committed_at']
+
+class Gist(BaseResource):
+ _strs = ['url', 'description', 'html_url', 'git_pull_url', 'git_push_url']
+ _ints = ['id', 'comments']
+ _bools = ['public']
+ _dates = ['created_at']
+ _map = {'user': User}
+ _list_map = {'files': File, 'forks': GistFork, 'history': GistHistory}
+
+ @property
+ def ri(self):
+ return ('users', self.user.login, self.id)
+
+ def __repr__(self):
+ return '<gist %s/%s>' % (self.user.login, self.description)
+
diff --git a/github3/models/orgs.py b/github3/models/orgs.py
new file mode 100644
index 0000000..1ce638e
--- /dev/null
+++ b/github3/models/orgs.py
@@ -0,0 +1,28 @@
+#!/usr/bin/env python
+# -*- encoding: utf-8 -*-
+#
+# author: David Medina
+
+from .base import BaseResource
+from .user import Plan
+
+class Org(BaseResource):
+ """Github Organization object model."""
+
+ _strs = [
+ 'login', 'url', 'avatar_url', 'name', 'company', 'blog', 'location', 'email'
+ 'html_url', 'type', 'billing_email']
+ _ints = [
+ 'id', 'public_repos', 'public_gists', 'followers', 'following',
+ 'total_private_repos', 'owned_private_repos', 'private_gists', 'disk_usage',
+ 'collaborators']
+ _dates = ['created_at']
+ _map = {'plan': Plan}
+ _writable = ['billing_email', 'blog', 'company', 'email', 'location', 'name']
+
+ @property
+ def ri(self):
+ return ('orgs', self.login)
+
+ def __repr__(self):
+ return '<org {0}>'.format(self.login)
diff --git a/github3/models/repos.py b/github3/models/repos.py
new file mode 100644
index 0000000..8dbe970
--- /dev/null
+++ b/github3/models/repos.py
@@ -0,0 +1,30 @@
+#!/usr/bin/env python
+# -*- encoding: utf-8 -*-
+#
+# author: David Medina
+
+from .base import BaseResource
+from .user import User
+from .orgs import Org
+
+class Repo(BaseResource):
+ _strs = [
+ 'url', 'html_url', 'clone_url', 'git_url', 'ssh_url', 'svn_url',
+ 'name', 'description', 'homepage', 'language', 'master_branch']
+ _bools = ['private', 'fork', 'has_issues', 'has_wiki', 'has_downloads']
+ _ints = ['forks', 'watchers', 'size', 'open_issues']
+ _dates = ['pushed_at', 'created_at']
+ _map = {
+ 'owner': User,
+ 'organization': Org,
+ 'parent': 'self',
+ 'source': 'self',
+ }
+
+ @property
+ def ri(self):
+ return ('repos', self.owner.login, self.name)
+
+ def __repr__(self):
+ return '<Repo {0}/{1}>'.format(self.owner.login, self.name)
+ # owner
diff --git a/github3/models/user.py b/github3/models/user.py
index cdbd04f..d58d9b2 100644
--- a/github3/models/user.py
+++ b/github3/models/user.py
@@ -5,18 +5,25 @@
from .base import BaseResource
+class Plan(BaseResource):
+ """Github Plan object model."""
+
+ _strs = ['name']
+ _ints = ['space', 'collaborators', 'private_repos']
+
+ def __repr__(self):
+ return '<Plan {0}>'.format(str(self.name))
+
class User(BaseResource):
"""Github User object model."""
_strs = [
'login','avatar_url', 'url', 'name', 'company', 'blog', 'location',
- 'email', 'bio', 'html_url']
+ 'email', 'bio', 'html_url', 'type']
_ints = ['id', 'public_repos', 'public_gists', 'followers', 'following']
_dates = ['created_at',]
_bools = ['hireable', ]
- # _map = {}
- # _writeable = []
@property
def ri(self):
@@ -25,26 +32,8 @@ class User(BaseResource):
def __repr__(self):
return '<User {0}>'.format(self.login)
- @property
def handler(self):
- return self._gh.user_handler(self.login)
-
- def get_followers(self, limit=None):
- return self.handler.followers(limit)
-
- def get_following(self, limit=None):
- return self.handler.following(limit)
-
- def repos(self, limit=None):
- return self._gh._get_resources(('users', self.login, 'repos'), Repo, limit=limit)
- def repo(self, reponame):
- return self._gh._get_resource(('repos', self.login, reponame), Repo)
-
- def orgs(self):
- return self._gh._get_resources(('users', self.login, 'orgs'), Org)
-
- def gists(self):
- return self._gh._get_resources(('users', self.login, 'gists'), Gist)
+ return self._gh.user_handler(self.login, force=True)
class AuthUser(User):
"""Github Current User object model."""
@@ -61,19 +50,5 @@ class AuthUser(User):
return ('user',)
def __repr__(self):
- return '<current-user {0}>'.format(self.login)
-
- def repos(self, limit=None):
- return self._gh._get_resources(('user', 'repos'), Repo, limit=limit)
-
- def repo(self, reponame):
- return self._gh._get_resource(('repos', self.login, reponame), Repo)
-
- def orgs(self, limit=None):
- return self._gh._get_resources(('user', 'orgs'), Org, limit=limit)
-
- def org(self, orgname):
- return self._gh._get_resource(('orgs', orgname), Org)
+ return '<AuthUser {0}>'.format(self.login)
- def gists(self, limit=None):
- return self._gh._get_resources('gists', Gist, limit=limit)