more object-orientation
This commit is contained in:
parent
e5fa7fc3a2
commit
1dbd19c6b2
1 changed files with 68 additions and 74 deletions
|
@ -1,38 +1,39 @@
|
||||||
const fetch = require('isomorphic-unfetch')
|
const fetch = require('isomorphic-unfetch')
|
||||||
|
|
||||||
class RadioManifest {
|
|
||||||
constructor (baseURL, options) {
|
|
||||||
this.baseURL = baseURL
|
|
||||||
this.options = options
|
|
||||||
|
|
||||||
const radiomanifest = fetch(`${baseURL}/radiomanifest.xml`)
|
|
||||||
return radiomanifest
|
|
||||||
}
|
|
||||||
|
|
||||||
getShowByName (showName) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
getStreaming () {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
getSchedule () {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
getShowAtTime () {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getStreaminfoUrl (siteurl) {
|
function getStreaminfoUrl (siteurl) {
|
||||||
return siteurl + '/streaminfo.json' // XXX: improve this logic
|
return siteurl + '/streaminfo.json' // XXX: improve this logic
|
||||||
}
|
}
|
||||||
function getManifestUrl (siteurl) {
|
function getManifestUrl (siteurl) {
|
||||||
return siteurl + '/radiomanifest.xml' // XXX: improve this logic
|
return siteurl + '/radiomanifest.xml' // XXX: improve this logic
|
||||||
}
|
}
|
||||||
function parseRadioManifest (xml) {
|
|
||||||
|
class Radio {
|
||||||
|
constructor (sources, schedule, shows, feed) {
|
||||||
|
this.streaming = new RadioStreaming(sources)
|
||||||
|
this.schedule = schedule
|
||||||
|
this.shows = shows
|
||||||
|
this.feed = feed
|
||||||
|
this.name = ''
|
||||||
|
}
|
||||||
|
|
||||||
|
getStreaming () {
|
||||||
|
return this.streaming
|
||||||
|
}
|
||||||
|
|
||||||
|
setName (name) {
|
||||||
|
this.name = name
|
||||||
|
}
|
||||||
|
|
||||||
|
getShowByName (showName) {
|
||||||
|
}
|
||||||
|
|
||||||
|
getSchedule () {
|
||||||
|
}
|
||||||
|
|
||||||
|
getShowAtTime () {
|
||||||
|
}
|
||||||
|
|
||||||
|
static fromDOM (xml) {
|
||||||
let res = xml.evaluate('/radio-manifest/streaming/source', xml)
|
let res = xml.evaluate('/radio-manifest/streaming/source', xml)
|
||||||
const sources = []
|
const sources = []
|
||||||
while (true) {
|
while (true) {
|
||||||
|
@ -53,7 +54,7 @@ function parseRadioManifest (xml) {
|
||||||
const scheduleEl = res.iterateNext()
|
const scheduleEl = res.iterateNext()
|
||||||
let schedule = null
|
let schedule = null
|
||||||
if (scheduleEl !== null) {
|
if (scheduleEl !== null) {
|
||||||
schedule = scheduleEl.getAttribute('url')
|
schedule = scheduleEl.getAttribute('src')
|
||||||
}
|
}
|
||||||
|
|
||||||
res = xml.evaluate('/radio-manifest/shows', xml)
|
res = xml.evaluate('/radio-manifest/shows', xml)
|
||||||
|
@ -63,23 +64,16 @@ function parseRadioManifest (xml) {
|
||||||
shows = showsEl.getAttribute('src')
|
shows = showsEl.getAttribute('src')
|
||||||
}
|
}
|
||||||
|
|
||||||
const manifest = new Radio(sources, schedule, shows)
|
res = xml.evaluate('/radio-manifest/feed', xml)
|
||||||
|
const feedEl = res.iterateNext()
|
||||||
|
let feed = null
|
||||||
|
if (feedEl !== null) {
|
||||||
|
feed = feedEl.getAttribute('src')
|
||||||
|
}
|
||||||
|
|
||||||
|
const manifest = new Radio(sources, schedule, shows, feed)
|
||||||
return manifest
|
return manifest
|
||||||
}
|
}
|
||||||
|
|
||||||
function Radio (sources, schedule, shows) {
|
|
||||||
this.streaming = new RadioStreaming(sources)
|
|
||||||
this.schedule = schedule
|
|
||||||
this.shows = shows
|
|
||||||
this.name = ''
|
|
||||||
}
|
|
||||||
|
|
||||||
Radio.prototype.getStreaming = function () {
|
|
||||||
return this.streaming
|
|
||||||
}
|
|
||||||
|
|
||||||
Radio.prototype.setName = function (name) {
|
|
||||||
this.name = name
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function RadioStreaming (sources) {
|
function RadioStreaming (sources) {
|
||||||
|
@ -108,7 +102,7 @@ async function get (siteurl, options) {
|
||||||
|
|
||||||
const parser = new DOMParser()
|
const parser = new DOMParser()
|
||||||
const dom = parser.parseFromString(text, 'text/xml')
|
const dom = parser.parseFromString(text, 'text/xml')
|
||||||
const manifest = parseRadioManifest(dom)
|
const manifest = Radio.fromDOM(dom)
|
||||||
|
|
||||||
resp = null
|
resp = null
|
||||||
try {
|
try {
|
||||||
|
@ -154,6 +148,6 @@ module.exports = {
|
||||||
},
|
},
|
||||||
parsers: {
|
parsers: {
|
||||||
M3U: parseM3U,
|
M3U: parseM3U,
|
||||||
radioManifest: parseRadioManifest
|
radioManifest: Radio.fromDOM
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue