aboutsummaryrefslogtreecommitdiffstats
path: root/github3/models/user.py
diff options
context:
space:
mode:
authorDavid Medina <davidmedina9@gmail.com>2011-11-01 12:33:05 +0100
committerDavid Medina <davidmedina9@gmail.com>2011-11-01 12:33:05 +0100
commit2506d0ed2e33955d9b46802ed735cd8547369bad (patch)
treeea02535e78ae2c59d9099850e5ab2d4b1d044f10 /github3/models/user.py
parentTesting post gist (diff)
parentDecouple Handlers and Models (diff)
downloadpython-github3-2506d0ed2e33955d9b46802ed735cd8547369bad.tar.xz
python-github3-2506d0ed2e33955d9b46802ed735cd8547369bad.zip
Merge branch 'handlers' into develop
Conflicts: github3/api.py
Diffstat (limited to 'github3/models/user.py')
-rw-r--r--github3/models/user.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/github3/models/user.py b/github3/models/user.py
new file mode 100644
index 0000000..d58d9b2
--- /dev/null
+++ b/github3/models/user.py
@@ -0,0 +1,54 @@
+#!/usr/bin/env python
+# -*- encoding: utf-8 -*-
+#
+# author: David Medina
+
+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', 'type']
+
+ _ints = ['id', 'public_repos', 'public_gists', 'followers', 'following']
+ _dates = ['created_at',]
+ _bools = ['hireable', ]
+
+ @property
+ def ri(self):
+ return ('users', self.login)
+
+ def __repr__(self):
+ return '<User {0}>'.format(self.login)
+
+ def handler(self):
+ return self._gh.user_handler(self.login, force=True)
+
+class AuthUser(User):
+ """Github Current User object model."""
+
+ _ints = [
+ 'id', 'public_repos', 'public_gists', 'followers', 'following',
+ 'total_private_repos', 'owned_private_repos', 'private_gists',
+ 'disk_usage', 'collaborators']
+ _map = {'plan': Plan}
+ _writeable = ['name', 'email', 'blog', 'company', 'location', 'hireable', 'bio']
+
+ @property
+ def ri(self):
+ return ('user',)
+
+ def __repr__(self):
+ return '<AuthUser {0}>'.format(self.login)
+