Информационные сообщения. Сделал выход из учётки. 1.1.0

master 1.1.0
inpos 2017-02-04 16:11:52 +03:00
parent 7f5e5f5ee4
commit e21b5def42
5 changed files with 120 additions and 22 deletions

View File

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<addon id="kodi-vk.inpos.ru" <addon id="kodi-vk.inpos.ru"
version="1.0.2" version="1.1.0"
name="VK Add-on" name="VK Add-on"
provider-name="inpos"> provider-name="inpos">
<requires> <requires>

View File

@ -1,8 +1,11 @@
v1.1.0 (2017-02-04)
- Добавил информационнаые оповещения, где необходимо. Сделал пункт "Выход из учётной записи" главного экрана.
v1.0.2 (2017-02-04) v1.0.2 (2017-02-04)
- Убрал дополнение из раздела Аудио. - Убрал дополнение из раздела Аудио.
v1.0.1 (2017-02-04) v1.0.1 (2017-02-04)
- Исправил зависимости в метаданных - Исправил зависимости в метаданных.
v1.0.0 (2017-02-03) v1.0.0 (2017-02-03)
- Подготовлена рабочая версия. Исправлены мелкие недочёты. - Подготовлена рабочая версия. Исправлены мелкие недочёты.
@ -14,10 +17,10 @@ v0.9.1 (2017-01-31)
- Добавлены поиск видеозаписей и закладки - Добавлены поиск видеозаписей и закладки
v0.9.0 (2017-01-30) v0.9.0 (2017-01-30)
- Сделан весь функционал, кроме поиска - Сделан весь функционал, кроме поиска.
v0.1.0 (2017-01-29) v0.1.0 (2017-01-29)
- Сделан весь функционал фидеозаписей и фотографий - Сделан весь функционал фидеозаписей и фотографий.
v0.0.1 (2017-01-26) v0.0.1 (2017-01-26)
- Начальная версия. Работает авторизация для получения токена. Запускается только начальный экран - Начальная версия. Работает авторизация для получения токена. Запускается только начальный экран.

View File

@ -72,6 +72,7 @@ _DO_FAVE_VIDEO = 'fave_video'
_DO_FAVE_PHOTO = 'fave_photo' _DO_FAVE_PHOTO = 'fave_photo'
_DO_FAVE_GROUPS = 'fave_groups' _DO_FAVE_GROUPS = 'fave_groups'
_DO_FAVE_USERS = 'fave_users' _DO_FAVE_USERS = 'fave_users'
_DO_LOGOUT = 'logout'
_NO_OWNER = '__no_owner__' _NO_OWNER = '__no_owner__'
@ -296,7 +297,13 @@ class KodiVKGUIFave(object):
p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), v.info.keys()))),) p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), v.info.keys()))),)
list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info[p_key]}) list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info[p_key]})
list_item.setProperty('IsPlayable', 'true') list_item.setProperty('IsPlayable', 'true')
v_source = self.root.gui.videos._get_video_source(v) if 'files' in v.info.keys():
if 'external' in v.info['files']:
v_source = self.root.gui.videos._get_video_source(v.info['files']['external'])
else:
v_source = _VK_VIDEO_SOURCE
else:
v_source = self.root.gui.videos._get_video_source(v.info['player'])
if v_source == _VK_VIDEO_SOURCE: if v_source == _VK_VIDEO_SOURCE:
params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE} params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE}
url = self.root.url(**params) url = self.root.url(**params)
@ -308,7 +315,8 @@ class KodiVKGUIFave(object):
s = re.compile('^http.*youtube.*(v=|\/embed\/)([^\?\&]+)[\?\&]?.*$') s = re.compile('^http.*youtube.*(v=|\/embed\/)([^\?\&]+)[\?\&]?.*$')
sr = s.findall(y_url) sr = s.findall(y_url)
if len(sr) < 0: if len(sr) < 0:
raise Exception('Unknown youtube url: %s' % (y_url,)) xbmc.log('WARN: Unknown youtube url: %s' % (y_url,))
continue
y_id = sr[0][1] y_id = sr[0][1]
url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id
else: else:
@ -451,12 +459,11 @@ class KodiVKGUIPhotos(object):
class KodiVKGUIVideos(object): class KodiVKGUIVideos(object):
def __init__(self, root): def __init__(self, root):
self.root = root self.root = root
def _get_video_source(self, v): def _get_video_source(self, v_url):
is_vk_url_re = re.compile('https?\:\/\/[^\/]*vk.com\/.*') is_vk_url_re = re.compile('https?\:\/\/[^\/]*vk.com\/.*')
is_youtube_url_re = re.compile('https\:\/\/www.youtube.com\/.*') is_youtube_url_re = re.compile('https\:\/\/www.youtube.com\/.*')
player_url = v.info['player'] if len(is_vk_url_re.findall(v_url)) > 0: return _VK_VIDEO_SOURCE
if len(is_vk_url_re.findall(player_url)) > 0: return _VK_VIDEO_SOURCE if len(is_youtube_url_re.findall(v_url)) > 0: return _YOUTUBE_VIDEO_SOURCE
if len(is_youtube_url_re.findall(player_url)) > 0: return _YOUTUBE_VIDEO_SOURCE
return _UNKNOWN_VIDEO_SOURCE return _UNKNOWN_VIDEO_SOURCE
def _main_video_search(self): def _main_video_search(self):
page = int(self.root.params['page']) page = int(self.root.params['page'])
@ -491,7 +498,8 @@ class KodiVKGUIVideos(object):
if s_win.isConfirmed(): if s_win.isConfirmed():
q = s_win.getText() q = s_win.getText()
else: else:
raise Exception("Search input was cancelled.") self.root.gui.notify(self.root.gui._string(400525), '')
return
else: else:
q = pickle.loads(binascii.unhexlify(q)) q = pickle.loads(binascii.unhexlify(q))
history = get_search_history(_FILE_VIDEO_SEARCH_HISTORY) history = get_search_history(_FILE_VIDEO_SEARCH_HISTORY)
@ -537,7 +545,13 @@ class KodiVKGUIVideos(object):
p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), v.info.keys()))),) p_key = 'photo_%d' % (max(map(lambda x: int(x.split('_')[1]), filter(lambda x: x.startswith('photo_'), v.info.keys()))),)
list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info[p_key]}) list_item.setArt({'thumb': v.info['photo_130'], 'icon': v.info['photo_130'], 'fanart': v.info[p_key]})
list_item.setProperty('IsPlayable', 'true') list_item.setProperty('IsPlayable', 'true')
v_source = self._get_video_source(v) if 'files' in v.info.keys():
if 'external' in v.info['files']:
v_source = self._get_video_source(v.info['files']['external'])
else:
v_source = _VK_VIDEO_SOURCE
else:
v_source = self._get_video_source(v.info['player'])
if v_source == _VK_VIDEO_SOURCE: if v_source == _VK_VIDEO_SOURCE:
params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE} params = {'do': _DO_PLAY_VIDEO, 'vid': v.id, 'source': _VK_VIDEO_SOURCE}
url = self.root.url(**params) url = self.root.url(**params)
@ -549,7 +563,8 @@ class KodiVKGUIVideos(object):
s = re.compile('^http.*youtube.*(v=|\/embed\/)([^\?\&]+)[\?\&]?.*$') s = re.compile('^http.*youtube.*(v=|\/embed\/)([^\?\&]+)[\?\&]?.*$')
sr = s.findall(y_url) sr = s.findall(y_url)
if len(sr) < 0: if len(sr) < 0:
raise Exception('Unknown youtube url: %s' % (y_url,)) xbmc.log('WARN: Unknown youtube url: %s' % (y_url,))
continue
y_id = sr[0][1] y_id = sr[0][1]
url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id url = u'plugin://plugin.video.youtube/?action=play_video&videoid=' + y_id
else: else:
@ -596,7 +611,11 @@ class KodiVKGUIVideos(object):
vid = self.root.params['vid'] vid = self.root.params['vid']
src = self.root.params['source'] src = self.root.params['source']
v = Entry('video.get', vid, self.root.conn) v = Entry('video.get', vid, self.root.conn)
v.set_info() try:
v.set_info()
except:
self.root.gui.notify(self.root.gui._string(400524), '')
return
if 'files' in v.info.keys(): if 'files' in v.info.keys():
paths = {} paths = {}
if src == _VK_VIDEO_SOURCE: if src == _VK_VIDEO_SOURCE:
@ -619,6 +638,10 @@ class KodiVkGUI:
self.photos = KodiVKGUIPhotos(self.root) self.photos = KodiVKGUIPhotos(self.root)
self.videos = KodiVKGUIVideos(self.root) self.videos = KodiVKGUIVideos(self.root)
self.faves = KodiVKGUIFave(self.root) self.faves = KodiVKGUIFave(self.root)
def notify(self,title, msg):
dialog = xbmcgui.Dialog()
dialog.notification(title, msg,
xbmcgui.NOTIFICATION_WARNING, 3000)
def _string(self, string_id): def _string(self, string_id):
return _addon.getLocalizedString(string_id).encode('utf-8') return _addon.getLocalizedString(string_id).encode('utf-8')
def _login_form(self): def _login_form(self):
@ -678,6 +701,10 @@ class KodiVkGUI:
self.root.add_folder(self._string(400512), {'do': _DO_MEMBERS, 'oid': -int(oid), 'page': 1}) self.root.add_folder(self._string(400512), {'do': _DO_MEMBERS, 'oid': -int(oid), 'page': 1})
if oid == self.root.u.id: if oid == self.root.u.id:
self.root.add_folder(self._string(400514), {'do': _DO_MAIN_FAVE}) self.root.add_folder(self._string(400514), {'do': _DO_MAIN_FAVE})
xbmcplugin.addDirectoryItem(_addon_id, None, xbmcgui.ListItem(''), isFolder = False)
xbmcplugin.addDirectoryItem(_addon_id, None, xbmcgui.ListItem(''), isFolder = False)
xbmcplugin.addDirectoryItem(_addon_id, None, xbmcgui.ListItem(''), isFolder = False)
self.root.add_folder(self._string(400526), {'do': _DO_LOGOUT})
xbmcplugin.endOfDirectory(_addon_id) xbmcplugin.endOfDirectory(_addon_id)
def __create_group_list_(self, groups): def __create_group_list_(self, groups):
for g in groups['items']: for g in groups['items']:
@ -773,13 +800,14 @@ class KodiVkGUI:
q = self.root.params['q'] q = self.root.params['q']
if q == 'none': if q == 'none':
s_win = xbmc.Keyboard() s_win = xbmc.Keyboard()
s_win.setHeading(self.root.gui._string(400515)) s_win.setHeading(self._string(400515))
s_win.setHiddenInput(False) s_win.setHiddenInput(False)
s_win.doModal() s_win.doModal()
if s_win.isConfirmed(): if s_win.isConfirmed():
q = s_win.getText() q = s_win.getText()
else: else:
raise Exception("Search input was cancelled.") self.notify(self._string(400525), '')
return
else: else:
q = pickle.loads(binascii.unhexlify(q)) q = pickle.loads(binascii.unhexlify(q))
history = get_search_history(_FILE_GROUP_SEARCH_HISTORY) history = get_search_history(_FILE_GROUP_SEARCH_HISTORY)
@ -817,7 +845,8 @@ class KodiVkGUI:
if s_win.isConfirmed(): if s_win.isConfirmed():
q = s_win.getText() q = s_win.getText()
else: else:
raise Exception("Search input was cancelled.") self.notify(self._string(400525), '')
return
else: else:
q = pickle.loads(binascii.unhexlify(q)) q = pickle.loads(binascii.unhexlify(q))
history = get_search_history(_FILE_USER_SEARCH_HISTORY) history = get_search_history(_FILE_USER_SEARCH_HISTORY)
@ -842,11 +871,21 @@ class KodiVkGUI:
params = {'do': _DO_VIDEO_SEARCH, 'q': query_hex, 'page': page + 1} params = {'do': _DO_VIDEO_SEARCH, 'q': query_hex, 'page': page + 1}
self.root.add_folder(self.root.gui._string(400602), params) self.root.add_folder(self.root.gui._string(400602), params)
xbmcplugin.endOfDirectory(_addon_id) xbmcplugin.endOfDirectory(_addon_id)
def _logout(self):
dialog = xbmcgui.Dialog()
ret = dialog.yesno(self._string(400526), self._string(400527), nolabel=self._string(400529), yeslabel=self._string(400528))
if ret:
_addon.setSetting(_SETTINGS_ID_TOKEN, '')
xbmc.executebuiltin("XBMC.Container.Update(path,replace)")
xbmc.executebuiltin("XBMC.ActivateWindow(Home)")
else:
return
class KodiVk: class KodiVk:
conn = None conn = None
def __init__(self): def __init__(self):
self.gui = KodiVkGUI(self) self.gui = KodiVkGUI(self)
self.conn = self.__connect_() self.conn = self.__connect_()
if not self.conn: raise Exception()
u_info = self.conn.users.get()[0] u_info = self.conn.users.get()[0]
self.u = User(u_info['id'], self.conn) self.u = User(u_info['id'], self.conn)
self.u.set_info() self.u.set_info()
@ -881,13 +920,18 @@ class KodiVk:
count = _LOGIN_RETRY count = _LOGIN_RETRY
while not token and count > 0: while not token and count > 0:
count -= 1 count -= 1
login, password = self.gui._login_form() try:
login, password = self.gui._login_form()
except:
self.gui.notify(self.gui._string(400525), '')
try: try:
conn = Connection(_APP_ID, login, password, scope = _SCOPE) conn = Connection(_APP_ID, login, password, scope = _SCOPE)
token = conn.conn._session.access_token token = conn.conn._session.access_token
_addon.setSetting(_SETTINGS_ID_TOKEN, token) _addon.setSetting(_SETTINGS_ID_TOKEN, token)
except vk.api.VkAuthError: except vk.api.VkAuthError:
continue continue
if not token:
return
return conn return conn
def parse_vk_player_html(self, v_url): def parse_vk_player_html(self, v_url):
p = re.compile('"url(\d+)":"([^"]+)"') p = re.compile('"url(\d+)":"([^"]+)"')
@ -906,8 +950,10 @@ class KodiVk:
return res return res
if __name__ == '__main__': if __name__ == '__main__':
kvk = KodiVk() try:
kvk = KodiVk()
except Exception, e:
sys.exit()
_DO = { _DO = {
_DO_HOME: kvk.gui._home, _DO_HOME: kvk.gui._home,
_DO_MAIN_PHOTO: kvk.gui.photos._main_photo, _DO_MAIN_PHOTO: kvk.gui.photos._main_photo,
@ -930,7 +976,8 @@ if __name__ == '__main__':
_DO_FAVE_VIDEO: kvk.gui.faves._video, _DO_FAVE_VIDEO: kvk.gui.faves._video,
_DO_FAVE_PHOTO: kvk.gui.faves._photo, _DO_FAVE_PHOTO: kvk.gui.faves._photo,
_DO_FAVE_USERS: kvk.gui.faves._users, _DO_FAVE_USERS: kvk.gui.faves._users,
_DO_FAVE_GROUPS: kvk.gui.faves._groups _DO_FAVE_GROUPS: kvk.gui.faves._groups,
_DO_LOGOUT: kvk.gui._logout
} }
_do_method = kvk.params['do'] _do_method = kvk.params['do']

View File

@ -100,6 +100,30 @@ msgctxt "#400523"
msgid "Safe video search" msgid "Safe video search"
msgstr "Safe video search" msgstr "Safe video search"
msgctxt "#400524"
msgid "Video does not exist"
msgstr "Video does not exist"
msgctxt "#400525"
msgid "Cancelled"
msgstr "Cancelled"
msgctxt "#400526"
msgid "Logout"
msgstr "[COLOR blue]Logout[/COLOR]"
msgctxt "#400527"
msgid "Logout_note"
msgstr "To use kodi-vk after logout you need to enter login and password again\n Confirm logout?"
msgctxt "#400528"
msgid "Yes"
msgstr "Yes"
msgctxt "#400529"
msgid "No"
msgstr "No"
msgctxt "#400601" msgctxt "#400601"
msgid "Previous page" msgid "Previous page"
msgstr "[B]Previous page[/B]" msgstr "[B]Previous page[/B]"

View File

@ -100,6 +100,30 @@ msgctxt "#400523"
msgid "Safe video search" msgid "Safe video search"
msgstr "Безопасный поиск видеозаписей" msgstr "Безопасный поиск видеозаписей"
msgctxt "#400524"
msgid "Video does not exist"
msgstr "Видеозапись отсутствует"
msgctxt "#400525"
msgid "Cancelled"
msgstr "Отменено"
msgctxt "#400526"
msgid "Logout"
msgstr "[COLOR blue]Выход из учётной записи[/COLOR]"
msgctxt "#400527"
msgid "Logout_note"
msgstr "Чтобы пользоваться kodi-vk после выхода, необходимо будет снова ввести логин и пароль\n Действительно выйти?"
msgctxt "#400528"
msgid "Yes"
msgstr "Да"
msgctxt "#400529"
msgid "No"
msgstr "Нет"
msgctxt "#400601" msgctxt "#400601"
msgid "Previous page" msgid "Previous page"
msgstr "[B]Предыдущая страница[/B]" msgstr "[B]Предыдущая страница[/B]"