Beispiel #1
0
 def __init__(self):
     super().__init__()
     self.ne = NetEase()
     self.uid = 0
     self.favorite_pid = 0   # 喜欢列表
Beispiel #2
0
class NetEaseAPI(object):
    """
    根据标准的数据模型将 网易云音乐的数据 进行格式化
    这个类也需要管理一个数据库,这个数据库中缓存过去访问过的\
    歌曲、列表、专辑图片等信息,以减少网络访问
    """

    user_info_filename = "netease_userinfo.json"

    def __init__(self):
        super().__init__()
        self.ne = NetEase()
        self.uid = 0
        self.favorite_pid = 0   # 喜欢列表

    def get_uid(self):
        return self.uid

    @staticmethod
    def is_response_avaible(data):
        """判断api返回的数据是否可用
        
        TODO: 应该写成一个decorator
        """
        if data is None:
            return False
        if data['code'] == 200:
            return True
        return False

    @staticmethod
    def is_response_ok(data):
        """check response status code"""
        if data is None:
            return False
        if not isinstance(data, dict):
            return True
        if data['code'] == 200:
            return True
        return False

    def check_login_successful(self):
        if self.ne.check_cookies():
            return True
        else:
            return False

    def login(self, username, password, phone=False):
        password = password.encode('utf-8')
        password = hashlib.md5(password).hexdigest()
        data = self.ne.login(username, password, phone)
        if not self.is_response_avaible(data):
            return data

        self.uid = data['account']['id']
        data = self.access_data_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def auto_login(self, username, pw_encrypt, phone=False):
        """login into website with username and password which has been ecrypted
        """
        data = self.ne.login(username, pw_encrypt, phone)
        if not self.is_response_avaible(data):
            return data

        self.uid = data['account']['id']
        data = self.access_data_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def get_captcha_url(self, captcha_id):
        return self.ne.get_captcha_url(captcha_id)

    def confirm_captcha(self, captcha_id, text):
        data = self.ne.confirm_captcha(captcha_id, text)
        if not self.is_response_avaible(data):
            return data

        if data['result'] is False:
            return data['result'], data['captchaId']
        else:
            return data['result'], None

    def get_song_detail(self, mid):
        data = self.ne.song_detail(mid)
        if not self.is_response_avaible(data):
            return data
        LOG.info("music id %d is available" % mid)
        songs = []
        for each in data['songs']:
            song = self.access_music(each)
            songs.append(song)
        return songs

    @web_cache_playlist
    def get_playlist_detail(self, pid, cache=True):
        """貌似这个请求会比较慢

        :param pid:
        :return:
        """
        data = self.ne.playlist_detail(pid)     # 当列表内容多的时候,耗时久
        if not self.is_response_avaible(data):
            return data

        data = data['result']

        data['uid'] = data['userId']
        data['type'] = data['specialType']

        for i, track in enumerate(data['tracks']):
            data['tracks'][i] = self.access_music(track)
        model = PlaylistModel(data).get_dict()
        LOG.debug('Update playlist cache finish: ' + model['name'])
        return model

    def get_user_playlist(self):
        data = self.ne.user_playlist(self.uid)
        if not self.is_response_avaible(data):
            return data

        playlist = data['playlist']
        result_playlist = []
        for i, brief_playlist in enumerate(playlist):
            brief_playlist['uid'] = brief_playlist['userId']
            brief_playlist['type'] = brief_playlist['specialType']

            if brief_playlist['type'] == 5:
                self.favorite_pid = brief_playlist['id']

            result_playlist.append(BriefPlaylistModel(brief_playlist).get_dict())
        return result_playlist

    def search(self, s, stype=1, offset=0, total='true', limit=60):
        data = self.ne.search(s, stype=1, offset=0, total='true', limit=60)
        if not self.is_response_avaible(data):
            return data
        if data['result']['songCount']:
            songs = data['result']['songs']
            for i, song in enumerate(songs):
                songs[i] = self.access_music_brief(song)
            return songs
        else:
            return []

    def get_artist_detail(self, artist_id):
        data = self.ne.artist_infos(artist_id)
        if not self.is_response_avaible(data):
            return data

        for i, track in enumerate(data['hotSongs']):
            data['hotSongs'][i] = self.access_music(track)

        for each_key in data['artist']:
            data[each_key] = data['artist'][each_key]

        model = ArtistDetailModel(data).get_dict()
        return model

    def get_album_detail(self, album_id):
        data = self.ne.album_infos(album_id)
        if not self.is_response_avaible(data):
            return data

        album = data['album']
        for i, track in enumerate(album['songs']):
            album['songs'][i] = self.access_music(track)
        model = AlbumDetailModel(album).get_dict()
        return model

    def is_playlist_mine(self, playlist_model):
        if playlist_model['uid'] == self.uid:
            return True
        return False

    def is_favorite_music(self, mid):
        data = self.get_playlist_detail(self.favorite_pid)
        if not self.is_response_avaible(data):
            return data
        tracks = data['tracks']
        for track in tracks:
            if track['id'] == mid:
                return True
        return False

    def is_favorite_playlist(self, playlist_model):
        if playlist_model['id'] == self.favorite_pid:
            return True
        return False

    def set_music_to_favorite(self, mid, flag):
        data = self.ne.set_music_favorite(mid, flag)
        return data

    def add_song_to_playlist(self, mid, pid):
        data = self.ne.add_music_to_playlist(mid, pid, 'add')
        if not self.is_response_avaible(data):
            return False
        return True

    def get_mv_detail(self, mvid):
        data = self.ne.get_mv_detail(mvid)
        if not self.is_response_avaible(data):
            return data

        data = data['data']
        brs = sorted(data['brs'].keys(), key=lambda num: int(num))
        data['url_low'] = data['brs'][brs[0]]
        data['url_high'] = data['brs'][brs[-1]]
        if len(brs) >= 2:
            data['url_middle'] = data['brs'][brs[-2]]
        else:
            data['url_middle'] = data['brs'][brs[-1]]
        model = MvModel(data).get_dict()
        return model

    def get_lyric_detail(self, music_id):
        data = self.ne.get_lyric_by_musicid(music_id)
        if not self.is_response_avaible(data):
            return data

        if 'lrc' not in data.keys():
            return None

        re_express = re.compile("\[\d+:\d+\.\d+\]")
        lyric = data['lrc']['lyric']
        lyric_l = re_express.split(lyric)
        data['lyric'] = lyric_l

        time_s = re_express.findall(lyric)
        for i, each in enumerate(time_s):
            m = int(each[1:3]) * 60000
            s = float(each[4:-1]) * 1000
            time_s[i] = int(m + s)
        data['time_sequence'] = list(time_s)
        data['time_sequence'].insert(0, 0)

        if 'tlyric' in data.keys():
            if data['tlyric']['lyric']:
                translate_lyric = data['tlyric']['lyric']
                tlyric_l = re_express.split(translate_lyric)
                data['translate_lyric'] = tlyric_l
            else:
                data['translate_lyric'] = []
        else:
            data['translate_lyric'] = []

        model = LyricModel(data).get_dict()

        return model

    def get_radio_songs(self):
        data = self.ne.get_radio_music()
        if not self.is_response_avaible(data):
            return data
        songs = data['data']
        for i, song in enumerate(songs):
            songs[i] = self.access_music_brief(song)
        return songs

    def get_simi_songs(self, mid, offset=0, limit=10):
        data = self.ne.get_similar_song(mid, offset, limit)
        if not self.is_response_avaible(data):
            return data
        songs = data['songs']
        for i, song in enumerate(songs):
            songs[i] = self.access_music(song)
        return songs

    def update_playlist_name(self, pid, name):
        data = self.ne.update_playlist_name(pid, name)
        if not self.is_response_avaible(data):
            return False
        return True

    def new_playlist(self, name):
        data = self.ne.new_playlist(self.uid, name)
        if not self.is_response_avaible(data):
            return None
        playlist = data['playlist']
        playlist['uid'] = playlist['userId']
        playlist['tracks'] = []
        playlist['type'] = playlist['adType']
        playlist_model = PlaylistModel(playlist)
        return playlist_model
    
    def delete_playlist(self, pid):
        data = self.ne.delete_playlist(pid)
        if not self.is_response_avaible(data):
            return False
        return True

    @func_coroutine
    def save_user_info(self, data_dict):
        if write_json_into_file(data_dict, DATA_PATH + self.user_info_filename):
            LOG.info("Save User info successfully")

    @staticmethod
    def access_music(music_data):
        """处理从服务获取的原始数据,对它的一些字段进行过滤和改名,返回符合标准的music数据

        :param music_data:
        :return:
        """
        music_data['url'] = music_data['mp3Url']
        song = MusicModel(music_data).get_dict()

        for i, artist in enumerate(music_data['artists']):
            artist_ = ArtistModel(artist).get_dict()
            song['artists'][i] = artist_

        song['album'] = AlbumModel(music_data['album']).get_dict()
        return song

    @staticmethod
    def access_music_brief(music_data):

        song = BriefMusicModel(music_data).get_dict()

        for i, artist in enumerate(song['artists']):
            artist = BriefArtistModel(artist).get_dict()
            song['artists'][i] = artist

        song['album'] = BriefAlbumModel(song['album']).get_dict()
        return song

    @staticmethod
    def access_data_user(user_data):
        user_data['avatar'] = user_data['profile']['avatarUrl']
        user_data['uid'] = user_data['account']['id']
        user_data['username'] = user_data['profile']['nickname']
        user = UserModel(user_data).get_dict()
        return user
Beispiel #3
0
class NetEaseAPI(object):
    """
    根据标准的数据模型将 网易云音乐的数据 进行格式化
    这个类也需要管理一个数据库,这个数据库中缓存过去访问过的歌曲、列表、专辑图片等信息,以减少网络访问
    """

    user_info_filename = "netease_userinfo.json"

    def __init__(self):
        super().__init__()
        self.ne = NetEase()
        self.uid = 0
        self.favorite_pid = 0  # 喜欢列表

    def get_uid(self):
        return self.uid

    def is_data_avaible(self, data):
        if data is None:
            return False
        if data['code'] == 200:
            return True
        return False

    def check_login_successful(self):
        if self.ne.check_cookies():
            return True
        else:
            return False

    def set_user(self, data):
        self.uid = data['uid']

    def login(self, username, password, phone=False):
        password = password.encode('utf-8')
        password = hashlib.md5(password).hexdigest()
        data = self.ne.login(username, password, phone)
        if not self.is_data_avaible(data):
            return data

        self.uid = data['account']['id']
        data = access_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def auto_login(self, username, pw_encrypt, phone=False):
        """login into website with username and password which has been ecrypted
        """
        data = self.ne.login(username, pw_encrypt, phone)
        if not self.is_data_avaible(data):
            return data

        self.uid = data['account']['id']
        data = access_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def get_captcha_url(self, captcha_id):
        return self.ne.get_captcha_url(captcha_id)

    def confirm_captcha(self, captcha_id, text):
        data = self.ne.confirm_captcha(captcha_id, text)
        if not self.is_data_avaible(data):
            return data

        if data['result'] is False:
            return data['result'], data['captchaId']
        else:
            return data['result'], None

    def get_song_detail(self, mid):
        data = self.ne.song_detail(mid)
        if not self.is_data_avaible(data):
            return data

        songs = []
        for each in data['songs']:
            song = access_music(each)
            songs.append(song)
        return songs

    @web_cache_playlist
    def get_playlist_detail(self, pid, cache=True):
        """貌似这个请求会比较慢

        :param pid:
        :return:
        """
        data = self.ne.playlist_detail(pid)  # 当列表内容多的时候,耗时久
        if not self.is_data_avaible(data):
            return data

        data = data['result']

        data['uid'] = data['userId']
        data['type'] = data['specialType']

        for i, track in enumerate(data['tracks']):
            data['tracks'][i] = access_music(track)
        model = PlaylistModel(data).get_dict()
        LOG.debug('Update playlist cache finish: ' + model['name'])
        return model

    # @login_required     # 装饰器,挺好玩(装逼)的一个东西
    def get_user_playlist(self):
        data = self.ne.user_playlist(self.uid)
        if not self.is_data_avaible(data):
            return data

        playlist = data['playlist']
        result_playlist = []
        for i, brief_playlist in enumerate(playlist):
            brief_playlist['uid'] = brief_playlist['userId']
            brief_playlist['type'] = brief_playlist['specialType']

            if brief_playlist['type'] == 5:
                self.favorite_pid = brief_playlist['id']

            result_playlist.append(
                BriefPlaylistModel(brief_playlist).get_dict())
        return result_playlist

    def search(self, s, stype=1, offset=0, total='true', limit=60):
        data = self.ne.search(s, stype=1, offset=0, total='true', limit=60)
        if not self.is_data_avaible(data):
            return data
        if data['result']['songCount']:
            songs = data['result']['songs']
            for i, song in enumerate(songs):
                songs[i] = access_brief_music(song)
            return songs
        else:
            return []

    def get_artist_detail(self, artist_id):
        data = self.ne.artist_infos(artist_id)
        if not self.is_data_avaible(data):
            return data

        for i, track in enumerate(data['hotSongs']):
            data['hotSongs'][i] = access_music(track)

        for each_key in data['artist']:
            data[each_key] = data['artist'][each_key]

        model = ArtistDetailModel(data).get_dict()
        return model

    def get_album_detail(self, album_id):
        data = self.ne.album_infos(album_id)
        if not self.is_data_avaible(data):
            return data

        album = data['album']
        for i, track in enumerate(album['songs']):
            album['songs'][i] = access_music(track)
        model = AlbumDetailModel(album).get_dict()
        return model

    def is_playlist_mine(self, playlist_model):
        if playlist_model['uid'] == self.uid:
            return True
        return False

    def is_favorite_music(self, mid):
        data = self.get_playlist_detail(self.favorite_pid)
        if not self.is_data_avaible(data):
            return data
        tracks = data['tracks']
        for track in tracks:
            if track['id'] == mid:
                return True
        return False

    def set_music_to_favorite(self, mid, flag):
        data = self.ne.set_music_favorite(mid, flag)
        return data

    def get_mv_detail(self, mvid):
        data = self.ne.get_mv_detail(mvid)
        if not self.is_data_avaible(data):
            return data

        data = data['data']
        brs = sorted(data['brs'].keys(), key=lambda num: int(num))
        data['url_low'] = data['brs'][brs[0]]
        data['url_high'] = data['brs'][brs[-1]]
        if len(brs) >= 2:
            data['url_middle'] = data['brs'][brs[-2]]
        else:
            data['url_middle'] = data['brs'][brs[-1]]
        model = MvModel(data).get_dict()
        return model

    def get_lyric_detail(self, music_id):
        data = self.ne.get_lyric_by_musicid(music_id)
        if not self.is_data_avaible(data):
            return data

        if 'lrc' not in data.keys():
            return None

        re_express = re.compile("\[\d+:\d+\.\d+\]")
        lyric = data['lrc']['lyric']
        lyric_l = re_express.split(lyric)
        data['lyric'] = lyric_l

        time_s = re_express.findall(lyric)
        for i, each in enumerate(time_s):
            m = int(each[1:3]) * 60000
            s = float(each[4:-1]) * 1000
            time_s[i] = int(m + s)
        data['time_sequence'] = list(time_s)
        data['time_sequence'].insert(0, 0)

        if 'tlyric' in data.keys():
            if data['tlyric']['lyric']:
                translate_lyric = data['tlyric']['lyric']
                tlyric_l = re_express.split(translate_lyric)
                data['translate_lyric'] = tlyric_l
            else:
                data['translate_lyric'] = []
        else:
            data['translate_lyric'] = []

        model = LyricModel(data).get_dict()

        return model

    @func_coroutine
    def save_user_info(self, data_dict):
        if write_json_into_file(data_dict,
                                DATA_PATH + self.user_info_filename):
            LOG.info("Save User info successfully")
Beispiel #4
0
 def __init__(self):
     super().__init__()
     self.ne = NetEase()
     self.uid = 0
     self.favorite_pid = 0  # 喜欢列表
Beispiel #5
0
class NetEaseAPI(object):
    """
    根据标准的数据模型将 网易云音乐的数据 进行格式化
    这个类也需要管理一个数据库,这个数据库中缓存过去访问过的歌曲、列表、专辑图片等信息,以减少网络访问
    """

    user_info_filename = "netease_userinfo.json"

    def __init__(self):
        super().__init__()
        self.ne = NetEase()
        self.uid = 0
        self.favorite_pid = 0   # 喜欢列表

    def get_uid(self):
        return self.uid

    def is_data_avaible(self, data):
        if data is None:
            return False
        if data['code'] == 200:
            return True
        return False

    def check_login_successful(self):
        if self.ne.check_cookies():
            return True
        else:
            return False

    def set_user(self, data):
        self.uid = data['uid']

    def login(self, username, password, phone=False):
        password = password.encode('utf-8')
        password = hashlib.md5(password).hexdigest()
        data = self.ne.login(username, password, phone)
        if not self.is_data_avaible(data):
            return data

        self.uid = data['account']['id']
        data = access_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def auto_login(self, username, pw_encrypt, phone=False):
        """login into website with username and password which has been ecrypted
        """
        data = self.ne.login(username, pw_encrypt, phone)
        if not self.is_data_avaible(data):
            return data

        self.uid = data['account']['id']
        data = access_user(data)
        data['code'] = 200
        self.save_user_info(data)
        return data

    def get_captcha_url(self, captcha_id):
        return self.ne.get_captcha_url(captcha_id)

    def confirm_captcha(self, captcha_id, text):
        data = self.ne.confirm_captcha(captcha_id, text)
        if not self.is_data_avaible(data):
            return data

        if data['result'] is False:
            return data['result'], data['captchaId']
        else:
            return data['result'], None

    def get_song_detail(self, mid):
        data = self.ne.song_detail(mid)
        if not self.is_data_avaible(data):
            return data

        songs = []
        for each in data['songs']:
            song = access_music(each)
            songs.append(song)
        return songs

    @web_cache_playlist
    def get_playlist_detail(self, pid, cache=True):
        """貌似这个请求会比较慢

        :param pid:
        :return:
        """
        data = self.ne.playlist_detail(pid)     # 当列表内容多的时候,耗时久
        if not self.is_data_avaible(data):
            return data

        data = data['result']

        data['uid'] = data['userId']
        data['type'] = data['specialType']

        for i, track in enumerate(data['tracks']):
            data['tracks'][i] = access_music(track)
        model = PlaylistModel(data).get_dict()
        LOG.debug('Update playlist cache finish: ' + model['name'])
        return model

    # @login_required     # 装饰器,挺好玩(装逼)的一个东西
    def get_user_playlist(self):
        data = self.ne.user_playlist(self.uid)
        if not self.is_data_avaible(data):
            return data

        playlist = data['playlist']
        result_playlist = []
        for i, brief_playlist in enumerate(playlist):
            brief_playlist['uid'] = brief_playlist['userId']
            brief_playlist['type'] = brief_playlist['specialType']

            if brief_playlist['type'] == 5:
                self.favorite_pid = brief_playlist['id']

            result_playlist.append(BriefPlaylistModel(brief_playlist).get_dict())
        return result_playlist

    def search(self, s, stype=1, offset=0, total='true', limit=60):
        data = self.ne.search(s, stype=1, offset=0, total='true', limit=60)
        if not self.is_data_avaible(data):
            return data
        if data['result']['songCount']:
            songs = data['result']['songs']
            for i, song in enumerate(songs):
                songs[i] = access_brief_music(song)
            return songs
        else:
            return []

    def get_artist_detail(self, artist_id):
        data = self.ne.artist_infos(artist_id)
        if not self.is_data_avaible(data):
            return data

        for i, track in enumerate(data['hotSongs']):
            data['hotSongs'][i] = access_music(track)

        for each_key in data['artist']:
            data[each_key] = data['artist'][each_key]

        model = ArtistDetailModel(data).get_dict()
        return model

    def get_album_detail(self, album_id):
        data = self.ne.album_infos(album_id)
        if not self.is_data_avaible(data):
            return data

        album = data['album']
        for i, track in enumerate(album['songs']):
            album['songs'][i] = access_music(track)
        model = AlbumDetailModel(album).get_dict()
        return model

    def is_playlist_mine(self, playlist_model):
        if playlist_model['uid'] == self.uid:
            return True
        return False

    def is_favorite_music(self, mid):
        data = self.get_playlist_detail(self.favorite_pid)
        if not self.is_data_avaible(data):
            return data
        tracks = data['tracks']
        for track in tracks:
            if track['id'] == mid:
                return True
        return False

    def set_music_to_favorite(self, mid, flag):
        data = self.ne.set_music_favorite(mid, flag)
        return data

    def get_mv_detail(self, mvid):
        data = self.ne.get_mv_detail(mvid)
        if not self.is_data_avaible(data):
            return data

        data = data['data']
        brs = sorted(data['brs'].keys(), key=lambda num: int(num))
        data['url_low'] = data['brs'][brs[0]]
        data['url_high'] = data['brs'][brs[-1]]
        if len(brs) >= 2:
            data['url_middle'] = data['brs'][brs[-2]]
        else:
            data['url_middle'] = data['brs'][brs[-1]]
        model = MvModel(data).get_dict()
        return model

    def get_lyric_detail(self, music_id):
        data = self.ne.get_lyric_by_musicid(music_id)
        if not self.is_data_avaible(data):
            return data

        if 'lrc' not in data.keys():
            return None

        re_express = re.compile("\[\d+:\d+\.\d+\]")
        lyric = data['lrc']['lyric']
        lyric_l = re_express.split(lyric)
        data['lyric'] = lyric_l

        time_s = re_express.findall(lyric)
        for i, each in enumerate(time_s):
            m = int(each[1:3]) * 60000
            s = float(each[4:-1]) * 1000
            time_s[i] = int(m + s)
        data['time_sequence'] = list(time_s)
        data['time_sequence'].insert(0, 0)

        if 'tlyric' in data.keys():
            if data['tlyric']['lyric']:
                translate_lyric = data['tlyric']['lyric']
                tlyric_l = re_express.split(translate_lyric)
                data['translate_lyric'] = tlyric_l
            else:
                data['translate_lyric'] = []
        else:
            data['translate_lyric'] = []

        model = LyricModel(data).get_dict()

        return model

    @func_coroutine
    def save_user_info(self, data_dict):
        if write_json_into_file(data_dict, DATA_PATH + self.user_info_filename):
            LOG.info("Save User info successfully")