5 Commits
v101 ... v106

Author SHA1 Message Date
57decd2fe2 support other services 2022-03-05 20:04:04 +01:00
e8d4f1f329 fix local build 2022-03-05 19:41:02 +01:00
21c4c64cde set tag 2022-03-05 19:33:56 +01:00
601ff195ff add headers
All checks were successful
continuous-integration/drone Build is passing
2022-03-05 19:10:41 +01:00
f6b708b247 add kodi demo
All checks were successful
continuous-integration/drone Build is passing
2022-03-05 17:49:14 +01:00
4 changed files with 88 additions and 26 deletions

View File

@ -7,8 +7,9 @@
"48": "icon-48.png", "48": "icon-48.png",
"128": "icon-128.png" "128": "icon-128.png"
}, },
"version": "100.0", "version": "106.0",
"manifest_version": 3, "manifest_version": 3,
"host_permissions": ["http://127.0.0.1:4000/jsonrpc"],
"permissions": ["tabs"], "permissions": ["tabs"],
"action": { "action": {
"default_title": "Proxy Stream", "default_title": "Proxy Stream",

View File

@ -5,5 +5,6 @@
</head> </head>
<body> <body>
<button>Proxy Stream</button> <button>Proxy Stream</button>
<button>Play on kodi</button>
</body> </body>
</html> </html>

View File

@ -1,33 +1,80 @@
let providers = new Map(); let providers = new Map()
providers.set("www.youtube.com", "youtube"); providers.set("www.youtube.com", "youtube")
providers.set("youtube.com", "youtube"); providers.set("youtube.com", "youtube")
providers.set("youtu.be", "youtube"); providers.set("youtu.be", "youtube")
providers.set("tv.nrk.no", "nrk"); providers.set("tv.nrk.no", "nrk")
providers.set("nx12210.your-storageshare.de", "nextcloud"); providers.set("seafile.purser.it", "seafile")
document.addEventListener("DOMContentLoaded", () => { document.addEventListener("DOMContentLoaded", () => {
let [button] = document.getElementsByTagName("button"); let [proxyButton, kodiButton] = document.getElementsByTagName("button")
button.addEventListener("click", (ev) => { proxyButton.addEventListener("click", (ev) => {
chrome.tabs.query({currentWindow: true, active: true}, (tabs) => { chrome.tabs.query({currentWindow: true, active: true}, (tabs) => {
let oldurl = new URL(tabs[0].url); let oldurl = new URL(tabs[0].url)
let newurl = new URL("https://stream.purser.it"); let newurl = new URL("https://stream.purser.it")
let search = new URLSearchParams(); let search = new URLSearchParams()
let hostname = oldurl.hostname.toLowerCase(); let hostname = oldurl.hostname.toLowerCase()
if(providers.has(hostname)) { if(providers.has(hostname)) {
if(hostname.includes("youtube.com")) { if(hostname.includes("youtube.com")) {
let newpath = oldurl.searchParams.get("v"); let newpath = oldurl.searchParams.get("v")
if((newpath instanceof String) || ((typeof newpath) === "string")) { if((newpath instanceof String) || ((typeof newpath) === "string")) {
newurl.pathname = "/" + newpath; newurl.pathname = "/" + newpath
} }
} else { } else {
newurl.pathname = oldurl.pathname; newurl.pathname = oldurl.pathname
} }
search.append("provider", providers.get(hostname)); search.append("provider", providers.get(hostname))
} }
newurl.search = search.toString(); newurl.search = search.toString()
let tab = {}; let tab = {}
tab.url = newurl.href; tab.url = newurl.href
chrome.tabs.create(tab); chrome.tabs.create(tab)
}); })
}); })
}); kodiButton.addEventListener("click", (ev) => {
chrome.tabs.query({currentWindow: true, active: true}, (tabs) => {
let oldurl = new URL(tabs[0].url)
let newurl = new URL("https://stream.purser.it")
let search = new URLSearchParams()
let hostname = oldurl.hostname.toLowerCase()
if(providers.has(hostname)) {
if(hostname.includes("youtube.com")) {
newurl = new URL("plugin://plugin.video.youtube")
search.append("action", "play_video")
let video_id = oldurl.searchParams.get("v")
if(video_id) {
search.append("videoid", video_id)
}
} else {
search.append("provider", providers.get(hostname))
search.append("raw", "true")
newurl.pathname = oldurl.pathname
}
}
newurl.search = search.toString()
let req = {
jsonrpc: "2.0",
method: "Player.Open",
id: 12345,
params: {
item: {
file: newurl.href
}
}
}
try {
fetch("http://127.0.0.1:4000/jsonrpc", {
method: "POST",
body: JSON.stringify(req),
headers: {
"Content-Type": "application/json charset=utf-8"
}
}).then(resp => console.log(resp))
} catch(e) {
console.log(e)
}
})
})
})

View File

@ -4,6 +4,14 @@ temp_name=$(head -c 20 /dev/random | xxd -p | tr -dc a-f0-9)
temp_dir="/tmp/${temp_name}" temp_dir="/tmp/${temp_name}"
chrome_dir="${temp_dir}/chrome" chrome_dir="${temp_dir}/chrome"
if [[ ! -n "${DRONE_TAG}" ]]
then
export DRONE_TAG=$(git describe --abbrev=0 | tr -dc v0-9)
fi
mkdir -p "${dir}/out"
rm -rf "${dir}/out"
mkdir -p "${temp_dir}/out" mkdir -p "${temp_dir}/out"
mkdir -p "${chrome_dir}" mkdir -p "${chrome_dir}"
@ -22,7 +30,7 @@ then
dbus-daemon --session --address="${DBUS_SESSION_BUS_ADDRESS}" & dbus-daemon --session --address="${DBUS_SESSION_BUS_ADDRESS}" &
fi fi
if [[ "${DISPLAY}test" == "test" ]] if [[ ! -n "${DISPLAY}" ]]
then then
export DISPLAY=:8819 export DISPLAY=:8819
Xvfb "${DISPLAY}" & Xvfb "${DISPLAY}" &
@ -39,7 +47,12 @@ fi
release_folder="${temp_dir}/out/proxy-stream-${DRONE_TAG}" release_folder="${temp_dir}/out/proxy-stream-${DRONE_TAG}"
cp -r "${dir}/chrome" "${release_folder}" cp -r "${dir}/chrome" "${release_folder}"
${browser} --disable-gpu --no-sandbox --user-data-dir=${chrome_dir} --pack-extension="${temp_dir}/out/proxy-stream-${DRONE_TAG}" --pack-extension-key="${temp_dir}/privkey.pem" if grep "/proc/1/cgroup" -q -F -e docker
then
${browser} --disable-gpu --no-sandbox --user-data-dir=${chrome_dir} --pack-extension="${temp_dir}/out/proxy-stream-${DRONE_TAG}" --pack-extension-key="${temp_dir}/privkey.pem"
else
${browser} --user-data-dir=${chrome_dir} --pack-extension="${temp_dir}/out/proxy-stream-${DRONE_TAG}" --pack-extension-key="${temp_dir}/privkey.pem"
fi
rm -rf "${release_folder}" rm -rf "${release_folder}"
mv "${temp_dir}/out" "${dir}/out" mv "${temp_dir}/out" "${dir}/out"