aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/vk/api.py
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2016-06-15 19:46:36 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2016-06-15 19:46:36 +0300
commit08f32d0ea1dfceb466c0d7990944523f1c253d16 (patch)
tree1bc5b078d2724dd34d2c9f97b9a7f9abc2af04fd /vk/api.py
parentapi.ConnectionError -> api.APIConnectionError (diff)
downloadvk-scripts-08f32d0ea1dfceb466c0d7990944523f1c253d16.tar.gz
vk-scripts-08f32d0ea1dfceb466c0d7990944523f1c253d16.zip
move API wrappers to a package
Diffstat (limited to 'vk/api.py')
-rw-r--r--vk/api.py76
1 files changed, 76 insertions, 0 deletions
diff --git a/vk/api.py b/vk/api.py
new file mode 100644
index 0000000..192b707
--- /dev/null
+++ b/vk/api.py
@@ -0,0 +1,76 @@
+# Copyright 2015 Egor Tensin <Egor.Tensin@gmail.com>
+# This file is licensed under the terms of the MIT License.
+# See LICENSE.txt for details.
+
+from collections import Iterable
+from enum import Enum
+import json
+from urllib.error import URLError
+import urllib.request
+
+import vk.error
+from vk.user import User
+
+class Language(Enum):
+ DEFAULT = None
+ EN = 'en'
+
+ def __str__(self):
+ return self.value
+
+class Method(Enum):
+ USERS_GET = 'users.get'
+ FRIENDS_GET = 'friends.get'
+
+ def __str__(self):
+ return self.value
+
+class API:
+ def __init__(self, lang=Language.DEFAULT):
+ self.lang = lang
+
+ def _lang_is_specified(self):
+ return self.lang != Language.DEFAULT
+
+ def _format_method_params(self, **kwargs):
+ params = '&'.join(map(lambda k: '{}={}'.format(k, kwargs[k]), kwargs))
+ if self._lang_is_specified():
+ if params:
+ params += '&'
+ params += 'lang={}'.format(self.lang)
+ return params
+
+ def _build_method_url(self, method, **kwargs):
+ return 'https://api.vk.com/method/{}?{}'.format(
+ method, self._format_method_params(**kwargs))
+
+ def _call_method(self, method, **kwargs):
+ url = self._build_method_url(method, **kwargs)
+ try:
+ with urllib.request.urlopen(url) as request:
+ response = json.loads(request.read().decode())
+ if 'response' not in response:
+ raise vk.error.InvalidResponseError(response)
+ return response['response']
+ except URLError:
+ raise vk.error.ConnectionError()
+
+ @staticmethod
+ def _format_param_values(xs):
+ if isinstance(xs, str):
+ return xs
+ if isinstance(xs, Iterable):
+ return ','.join(map(str, xs))
+ return str(xs)
+
+ def users_get(self, user_ids, fields=()):
+ return map(User, self._call_method(
+ Method.USERS_GET,
+ user_ids=self._format_param_values(user_ids),
+ fields=self._format_param_values(fields)))
+
+ def friends_get(self, user_id, fields=()):
+ return map(User, self._call_method(
+ Method.FRIENDS_GET,
+ user_id=str(user_id),
+ fields=self._format_param_values(fields)))