1.1.1 • Published 3 years ago
node-subscene-api v1.1.1
subscene
Small project for Download Subtitle From SUBSCENE
Important : This is not an official project, so there is no guarantee that it will work for a long time.
Installation
npm i node-subscene-api
Require Module
const subscene = require("node-subscene-api")How to search a movie?
const subscene = require("node-subscene-api") //require Module
//Search A Movie/series Name Query
subscene.search(query).then(results=> {
  //results may be an array or null
}).catch(err=> {
  //Handle Errors
})
/* An Example For How to Use Search Function*/
subscene.search("Money heist").then(results=> {
  /*
  [
    {
      title:"money heist",
      path:"/subtitle/money-heist"
    },
    {
      title:".....",
      path:"...."
    }.....
  ]
  */
})How to get Subtitles?
subscene.getSubtitles(moviePath,datas).then(subtitles=> {// "moviePath" is the "path" returned in the subscene.search() function
  console.log(subtitles)
  /*
    {
      english:[
        {
          title:"money-heist s01e01",
          path:"/money-heist/english/028292",
          lang:"English"
        },
        {
          title:"bababa",
          path:"baba a",
          lang:"English"
        }
      ],
      hindi:[
        {
          title:"hindi sub name",
          path:"some path",
          lang:"Hindi"
        }....
      ]....
    },
    
  */
}).catch(err=>console.log(err))datas : Boolean (default=false)
if you pass datas as true the response will be contain a key named datas as an object
eg :-
     response={
       english:[...],
       arabic:[...],
       datas:{
         title:"Dark",
         year:"2017",
         poster:"https://poster.url",
         imdb:tt00000
       }
     }How To Download Subtitle?
subscene.download(subtitlePath,options).then(files=>{  // "subtitlePath" is the "path" returned in the subscene.getSubtitles() function
  console.log(files)
  /*
   A buffer will return according to the options
  */
  
}).catch(err=>console.log(err))options : {object}
zip :(default false) :
The zip option refers to whether the file buffer to be returned is zip file buffer or unzipped type buffer. default it will be return unzipped type buffer,
If the zip option is true then return value will be an Object 
example :-
subscene.download(subPath,{zip:true}).then(file=>{
  console.log(file)
  /*
  {
    zip: <Buffer 12 12 221 122...>
  }
  */
})if the zip option is false then the response will be an Array
example :-
subscene.download(subPath).then(file=>{
  console.log(file)
  /*
    [
      {
        filename:"money heist s05e01.srt",
        file:<Buffer 00 11 11 22 112...>
      },
      {
        filename:"money-heist s05e02.srt",
        file:<some buffer>
      }....
    ]
  */
})One More Example to easly understand
subscene.search("money heist").then(res=>{
  /*
  [
  {title:"money heist", path:"some path"}...
  ]
  */
  var selectedSeriesPath=res[0].path //select a path
  subscene.getSubtitles(selectedSeriesPath).then(subtitles=>{
    /*
    {
      english:[
      {title:"some title",path:"some path",lang:"English"}...
      ]
    }...
    */
    var selectedSubtitlePath=subtitles.english[0].path //select a Subtitile path
    subscene.download(selectedSubtitlePath,{zip:false}).then((file)=>{
      /*
      [
      {
        filename:"filename",
        file: buffer
      }...
      ]
      */
      console.log(file[0].file.toString())
      /*
      1
      00:00:01,500 --> 00:00:05,200
      Some diloge is here
      ..
      ..
      ..
      */
    })
  })
})