mirror of
https://github.com/RGBCube/GitHubWrapper
synced 2025-05-16 22:15:09 +00:00
Objects
This commit is contained in:
parent
3e49dba6a5
commit
9a2889702b
1 changed files with 64 additions and 4 deletions
|
@ -7,7 +7,7 @@ import aiohttp
|
||||||
from . import http
|
from . import http
|
||||||
|
|
||||||
__all__ = (
|
__all__ = (
|
||||||
'User',
|
'User'
|
||||||
)
|
)
|
||||||
|
|
||||||
def dt_formatter(time_str):
|
def dt_formatter(time_str):
|
||||||
|
@ -68,8 +68,6 @@ class User(_BaseUser):
|
||||||
else:
|
else:
|
||||||
setattr(self, key, value)
|
setattr(self, key, value)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
setattr(self, key, value)
|
setattr(self, key, value)
|
||||||
|
|
||||||
|
@ -80,4 +78,66 @@ class User(_BaseUser):
|
||||||
async def get_user(cls, session: aiohttp.ClientSession, username: str) -> 'User':
|
async def get_user(cls, session: aiohttp.ClientSession, username: str) -> 'User':
|
||||||
"""Returns a User object from the username, with the mentions slots."""
|
"""Returns a User object from the username, with the mentions slots."""
|
||||||
response = await http.get_user(session, username)
|
response = await http.get_user(session, username)
|
||||||
return User(response, session)
|
return User(response, session)
|
||||||
|
|
||||||
|
class PartialUser(_BaseUser):
|
||||||
|
__slots__ = (
|
||||||
|
'site_admin',
|
||||||
|
'html_url',
|
||||||
|
'created_at',
|
||||||
|
) + _BaseUser.__slots__
|
||||||
|
|
||||||
|
def __init__(self, response: dict, session: aiohttp.ClientSession) -> None:
|
||||||
|
super().__init__(response, session)
|
||||||
|
self.site_admin = response.get('site_admin')
|
||||||
|
self.html_url = response.get('html_url')
|
||||||
|
self.avatar_url = response.get('avatar_url')
|
||||||
|
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return f'<PartialUser; login: {self.login}, id: {self.id}, site_admin: {self.site_admin}, html_url: {self.html_url}, created_at: {repr_dt(self.created_at)}>'
|
||||||
|
|
||||||
|
async def _get_user(self):
|
||||||
|
"""Upgrades the PartialUser to a User object."""
|
||||||
|
response = await http.get_user(self.session, self.login)
|
||||||
|
return User(response, self.session)
|
||||||
|
|
||||||
|
|
||||||
|
class Repository(APIOBJECT):
|
||||||
|
__slots__ = (
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'owner',
|
||||||
|
'size'
|
||||||
|
'created_at',
|
||||||
|
'url',
|
||||||
|
'html_url',
|
||||||
|
'archived',
|
||||||
|
'disabled',
|
||||||
|
'updated_at',
|
||||||
|
'open_issues_count',
|
||||||
|
'default_branch',
|
||||||
|
'clone_url',
|
||||||
|
'stargazers_count',
|
||||||
|
'watchers_count',
|
||||||
|
'forks',
|
||||||
|
'license'
|
||||||
|
)
|
||||||
|
def __init__(self, response: dict, session: aiohttp.ClientSession) -> None:
|
||||||
|
super().__init__(response, session)
|
||||||
|
tmp = self.__slots__
|
||||||
|
keys = {key: value for key,value in self.response.items() if key in tmp}
|
||||||
|
for key, value in key.items():
|
||||||
|
if key == 'owner':
|
||||||
|
self.owner = PartialUser(value, self.session)
|
||||||
|
return
|
||||||
|
|
||||||
|
if '_at' in key and value is not None:
|
||||||
|
setattr(self, key, dt_formatter(value))
|
||||||
|
return
|
||||||
|
|
||||||
|
setattr(self, key, value)
|
||||||
|
|
||||||
|
def __repr__(self) -> str:
|
||||||
|
return f'<Repository; id: {self.id}, name: {self.name}, owner: {self.owner}, created_at: {repr_dt(self.created_at)}, default_branch: {self.default_branch}, license: {self.license}, >'
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue