Giter Club home page Giter Club logo

vidsrc-api-stermio's Introduction

vidsrc-api

Status Deployment

STATUS- WORKING - (UPDATED MAR/31/24)

  • Added stable fixes for most of the sources so it wont break too often.
  • Everything Works currently and the speed has also increased in the latest commit dut o use of non-blocking async functions.
  • Still the code may have some bugs,so feel free to post bugs in the issue section :)

A simple web scrapper based on this resolver.

About

  • Deploying methods.

    • Any Platform

      Project specifically made to run on vercel,but easy to deploy on other platforms.Just check the running fastapi on the specific platform.

    • Vercel

      Project is easy to deploy on vercel.

      1. Fork this repo.

      2. Open vercel and create new project and choose your forked repo.

      3. Use the default settings and click deploy.

      4. Your build will surely fail because of this

        img

        *vercel's latest update.Node.js version 20.x dosent fully support python.

      5. Now open the project's settings and scroll down.Now you can see a row caled Node Version. CHANGE it to 18.x

        img

        *there's an detailed explanation in this issue link

    • Vercel easy

      Or if vercel fixes this bug,you can use this button.But vercel didnt fix this yet.

      Deploy with Vercel

      IMPORTANT : Vercel is facing a bug recently so setting node version to 18.x is a fix for it.

      *there's an detailed explanation in this issue link

  • Running it locally

    1.Fork and Clone the repo.

    2.Create a virtial env if you want.

    3.install the deps.[pip install -r requirements.txt]

    4.open models/utils.py and change the value of BASE to your api-base-url/deployment-base-url.( for subtitle )

    5.install uvicorn via pip install uvicorn & run it using uvicorn.[uvicorn main:app --reload --port=8000]

  • If you liked the project and updates buy me a coffee :)

  • If any issues,drop an issue on github issues.

FEATURES

- async support - Most process are async but still some fixes are needed.
- very fast results
- subtitle support for every sources.

NOTES

- Dont overload the deployment.
- This api is made for educational purpouse only. This is just a simple scrapper built arround `https://github.com/Ciarands` vidsrc downloader.This project was only made to prevent ads and redirects caused by the `iframe`s
- This api isnt a copy of the inspired project,but its a complete reqrite of code to make it work as an api and use async style to give vary fast results.
- Dont perform bulk request to the api and store the m3u8's returned,cuz they may not work after 24 hours or so.This api scrape websites that have `video on demand` feature so storing it is useless.

USAGE (GET)

  • example base url: https://api.vercel.app

  • endpoints:

    • /vidsrc/{db_id} - vidsrc.to
    • /vsrcme/{db_id} - vidsrc.me
    • /streams/{db_id} - get streams from all 4 sources in one request.
    • /subs/?url={[email protected]}
  • parameters:

    • s - season (series only)
    • e - episodes (series only)
    • l - language(subtitle)
  • example url (movie) : https://api.vercel.app/vidsrc/ttXXXXXX

  • example url (series) : https://api.vercel.app/vidsrc/ttXXXXXX?s=1&e=2

RESPONSE SCEMA

[UPDATE] Added a common response scheam for the endpoints,so every source is an element of an array.And the api retruns an array.

  • Working
{
    "status":200,
    "info":"success",
    "sources":[
      {
        "name": "SOURCE_NAME",
        "data": {
          "stream": "FILE.m3u8",
          "subtitle": [
            {
              "lang":"LANGUAGE",
              "file":"FILE.srt"
            }
            {
              "lang":"LANGUAGE2",
              "file":"FILE2.srt"
            }
          ]
        }
      },
      {
        "name": "SOURCE_NAME2",
        "data": {
          "stream": "FILE2.m3u8",
          "subtitle": [
            {
              "lang":"LANGUAGE",
              "file":"FILE.srt"
            }
            {
              "lang":"LANGUAGE2",
              "file":"FILE2.srt"
            }
          ]
        }
      }
    ]
}
  • Error/Stream Unavailable
{
    "status":200,
    "info":"success",
    "sources":[]
}

### ERROR CODES

ERROR CODES

TODO


### OTHER PROJECTS
- [cool-proxy](https://github.com/cool-dev-guy/cool-proxy) - A proxy made in C++

vidsrc-api-stermio's People

Contributors

cool-dev-guy avatar rageshantonyhm avatar rageshantony avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.