Esempio n. 1
0
def get_hdonline(url):
    attempt = 1
    MAX_ATTEMPTS = 5

    xbmc.log(url)

    while attempt < MAX_ATTEMPTS:
        if attempt > 1:
            sleep(2)
        url_play = ''
        notify(u'Lấy link lần thứ #%s'.encode("utf-8") % attempt)
        attempt += 1
        response = fetch_data(url)
        if not response:
            return ''

        match = re.search(r'\-(\d+)\.?\d*?\.html$', url)
        if not match:
            return ''
        fid = match.group(1)

        match = re.search(r'\-tap-(\d+)-[\d.]+?\.html$', url)
        if not match:
            ep = 1
        else:
            ep = match.group(1)

        match = re.search(r'\|(\w{86}|\w{96})\|', response.body)
        if match:
            token = match.group(1)

            match = re.search(r'\|14(\d+)\|', response.body)
            token_key = '14' + match.group(1)

            token = token + '-' + token_key

            _x = random.random()
            url_play = (
                'http://hdonline.vn/frontend/episode/xmlplay?ep=%s&fid=%s&format=json&_x=%s&token=%s'
                % (ep, fid, _x, token))
            break
        else:
            match = re.search(r'"file":"(.*?)","', response.body)
            if match:
                url_play = 'http://hdonline.vn' + match.group(1).replace(
                    '\/', '/') + '&format=json'
                url_play = url_play.replace('ep=1', 'ep=' + str(ep))
                break
    if len(url_play) == 0:
        notify(u'Không lấy được link.')
        return ''

    headers = {
        'User-Agent':
        'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36',
        'Referer': url,
        'Accept': 'application/json, text/javascript, */*; q=0.01',
        'Cookie': response.cookiestring
    }
    response = fetch_data(url_play, headers)

    json_data = json.loads(response.body)
    video_url = json_data['file']
    if json_data.get('level') and len(json_data['level']) > 0:
        video_url = json_data['level'][len(json_data['level']) - 1]['file']

    subtitle_url = ''
    if json_data.get('subtitle') and len(json_data['subtitle']) > 0:
        for subtitle in json_data['subtitle']:
            subtitle_url = subtitle['file'].encode('utf-8')
            if subtitle['code'] == 'vi':
                subtitle_url = subtitle['file'].encode('utf-8')
                break

    xbmc.log(video_url)

    if len(subtitle_url) > 0:
        subtitle_url = ('http://data.hdonline.vn/api/vsub.php?url=%s' %
                        subtitle_url)
        return video_url, subtitle_url
    else:
        return video_url, subtitle_url
Esempio n. 2
0
def get_hdonline(url):
    attempt = 1
    MAX_ATTEMPTS = 5

    xbmc.log(url)

    while attempt < MAX_ATTEMPTS:
        if attempt > 1:
            sleep(2)
        url_play = ""
        notify(u"Lấy link lần thứ #%s".encode("utf-8") % attempt)
        attempt += 1
        response = fetch_data(url)
        if not response:
            return ""

        match = re.search(r"\-(\d+)\.?\d*?\.html$", url)
        if not match:
            return ""
        fid = match.group(1)

        match = re.search(r"\-tap-(\d+)-[\d.]+?\.html$", url)
        if not match:
            ep = 1
        else:
            ep = match.group(1)

        match = re.search(r"\|(\w{86}|\w{96})\|", response.body)
        if match:
            token = match.group(1)

            match = re.search(r"\|14(\d+)\|", response.body)
            token_key = "14" + match.group(1)

            token = token + "-" + token_key

            _x = random.random()
            url_play = "http://hdonline.vn/frontend/episode/xmlplay?ep=%s&fid=%s&format=json&_x=%s&token=%s" % (
                ep,
                fid,
                _x,
                token,
            )
            break
        else:
            match = re.search(r'"file":"(.*?)","', response.body)
            if match:
                url_play = "http://hdonline.vn" + match.group(1).replace("\/", "/") + "&format=json"
                url_play = url_play.replace("ep=1", "ep=" + str(ep))
                break
    if len(url_play) == 0:
        notify(u"Không lấy được link.")
        return ""

    headers = {
        "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36",
        "Referer": url,
        "Accept": "application/json, text/javascript, */*; q=0.01",
        "Cookie": response.cookiestring,
    }
    response = fetch_data(url_play, headers)

    json_data = json.loads(response.body)
    video_url = json_data["file"]
    if json_data.get("level") and len(json_data["level"]) > 0:
        video_url = json_data["level"][len(json_data["level"]) - 1]["file"]

    subtitle_url = ""
    if json_data.get("subtitle") and len(json_data["subtitle"]) > 0:
        for subtitle in json_data["subtitle"]:
            subtitle_url = subtitle["file"].encode("utf-8")
            if subtitle["code"] == "vi":
                subtitle_url = subtitle["file"].encode("utf-8")
                break

    xbmc.log(video_url)

    if len(subtitle_url) > 0:
        subtitle_url = "http://data.hdonline.vn/api/vsub.php?url=%s" % subtitle_url
        return video_url, subtitle_url
    else:
        return video_url, subtitle_url
Esempio n. 3
0
def get_fshare(url):
    login_url = 'https://www.fshare.vn/login'
    logout_url = 'https://www.fshare.vn/logout'
    download_url = 'https://www.fshare.vn/download/get'

    username = myaddon.getSetting('usernamef')
    password = myaddon.getSetting('passwordf')

    try:
        url_account = 'http://www.aku.vn/linksvip'
        headers = {
            'Referer':
            'http://aku.vn/linksvip',
            'User-Agent':
            'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36'
        }
        response = fetch_data(url_account,
                              headers=headers,
                              data={'url_download': url})
        link_match = re.search("<a href=http://download(.*?)\starget=_blank",
                               response.body)
        if link_match:
            return 'http://download' + link_match.group(1)

    except Exception as e:
        pass

    if len(username) == 0 or len(password) == 0:
        try:
            url_account = VIETMEDIA_HOST + '?action=fshare_account'

            response = fetch_data(url_account)
            json_data = json.loads(response.body)
            username = json_data['username']
            password = json_data['password']
        except Exception as e:
            pass

    print 'username: '******'password: '******'Bạn chưa nhập tài khoản fshare'.encode("utf-8"))
        return

    response = fetch_data(login_url)
    if not response:
        return

    csrf_pattern = '\svalue="(.+?)".*name="fs_csrf"'

    csrf = re.search(csrf_pattern, response.body)
    fs_csrf = csrf.group(1)

    headers = {
        'User-Agent':
        'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2228.0 Safari/537.36 VietMedia/1.0',
        'Cookie': response.cookiestring
    }

    data = {
        "LoginForm[email]": username,
        "LoginForm[password]": password,
        "fs_csrf": fs_csrf
    }

    response = fetch_data(login_url, headers, data)
    headers['Cookie'] = response.cookiestring
    headers['Referer'] = url
    direct_url = ''
    attempt = 1
    MAX_ATTEMPTS = 8
    file_id = os.path.basename(url)
    if response and response.status == 302:
        notify(u'Đăng nhập fshare thành công'.encode("utf-8"))
        while attempt < MAX_ATTEMPTS:
            if attempt > 1: sleep(2)
            notify(u'Lấy link lần thứ #%s'.encode("utf-8") % attempt)
            attempt += 1

            response = fetch_data(url, headers, data)

            if response.status == 200:
                csrf = re.search(csrf_pattern, response.body)
                fs_csrf = csrf.group(1)
                data = {
                    'fs_csrf': fs_csrf,
                    'ajax': 'download-form',
                    'DownloadForm[linkcode]': file_id
                }

                response = fetch_data(download_url, headers, data)

                json_data = json.loads(response.body)

                if json_data.get('url'):
                    direct_url = json_data['url']
                    break
                elif json_data.get('msg'):
                    notify(json_data['msg'].encode("utf-8"))
            elif response.status == 302:
                direct_url = response.headers['location']
                break
            else:
                notify(u'Lỗi khi lấy link, mã lỗi #%s. Đang thử lại...'.encode(
                    "utf-8") % response.status)

        response = fetch_data(logout_url, headers)
        if response.status == 302:
            notify(u'Đăng xuất fshare thành công'.encode("utf-8"))
    else:
        notify(u'Đăng nhập không thành công, kiểm tra lại tài khoản'.encode(
            "utf-8"))
    if len(direct_url) > 0:
        notify(u'Đã lấy được link'.encode("utf-8"))
    else:
        notify(u'Không được link, bạn vui lòng kiểm tra lại tài khoản'.encode(
            "utf-8"))

    return direct_url
Esempio n. 4
0
def get_fshare(url):
    login_url = "https://www.fshare.vn/login"
    logout_url = "https://www.fshare.vn/logout"
    download_url = "https://www.fshare.vn/download/get"

    username = myaddon.getSetting("usernamef")
    password = myaddon.getSetting("passwordf")

    try:
        url_account = "http://www.aku.vn/linksvip"
        headers = {
            "Referer": "http://aku.vn/linksvip",
            "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36",
        }
        response = fetch_data(url_account, headers=headers, data={"url_download": url})
        link_match = re.search("<a href=http://download(.*?)\starget=_blank", response.body)
        if link_match:
            return "http://download" + link_match.group(1)

    except Exception as e:
        pass

    if len(username) == 0 or len(password) == 0:
        try:
            url_account = VIETMEDIA_HOST + "?action=fshare_account"

            response = fetch_data(url_account)
            json_data = json.loads(response.body)
            username = json_data["username"]
            password = json_data["password"]
        except Exception as e:
            pass

    print "username: "******"password: "******"Bạn chưa nhập tài khoản fshare".encode("utf-8"))
        return

    response = fetch_data(login_url)
    if not response:
        return

    csrf_pattern = '\svalue="(.+?)".*name="fs_csrf"'

    csrf = re.search(csrf_pattern, response.body)
    fs_csrf = csrf.group(1)

    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2228.0 Safari/537.36 VietMedia/1.0",
        "Cookie": response.cookiestring,
    }

    data = {"LoginForm[email]": username, "LoginForm[password]": password, "fs_csrf": fs_csrf}

    response = fetch_data(login_url, headers, data)
    headers["Cookie"] = response.cookiestring
    headers["Referer"] = url
    direct_url = ""
    attempt = 1
    MAX_ATTEMPTS = 8
    file_id = os.path.basename(url)
    if response and response.status == 302:
        notify(u"Đăng nhập fshare thành công".encode("utf-8"))
        while attempt < MAX_ATTEMPTS:
            if attempt > 1:
                sleep(2)
            notify(u"Lấy link lần thứ #%s".encode("utf-8") % attempt)
            attempt += 1

            response = fetch_data(url, headers, data)

            if response.status == 200:
                csrf = re.search(csrf_pattern, response.body)
                fs_csrf = csrf.group(1)
                data = {"fs_csrf": fs_csrf, "ajax": "download-form", "DownloadForm[linkcode]": file_id}

                response = fetch_data(download_url, headers, data)

                json_data = json.loads(response.body)

                if json_data.get("url"):
                    direct_url = json_data["url"]
                    break
                elif json_data.get("msg"):
                    notify(json_data["msg"].encode("utf-8"))
            elif response.status == 302:
                direct_url = response.headers["location"]
                break
            else:
                notify(u"Lỗi khi lấy link, mã lỗi #%s. Đang thử lại...".encode("utf-8") % response.status)

        response = fetch_data(logout_url, headers)
        if response.status == 302:
            notify(u"Đăng xuất fshare thành công".encode("utf-8"))
    else:
        notify(u"Đăng nhập không thành công, kiểm tra lại tài khoản".encode("utf-8"))
    if len(direct_url) > 0:
        notify(u"Đã lấy được link".encode("utf-8"))
    else:
        notify(u"Không được link, bạn vui lòng kiểm tra lại tài khoản".encode("utf-8"))

    return direct_url