Compare commits

..

No commits in common. "master" and "v106" have entirely different histories.
master ... v106

6 changed files with 60 additions and 109 deletions

View File

@ -1,13 +1,13 @@
kind: pipeline kind: pipeline
name: default name: default
steps: steps:
- name: compile-extensions - name: compile-chrome
image: roypur/extension-packer:latest image: roypur/chrome-packer:latest
environment: environment:
CHROME_PRIVKEY: CHROME_PRIVKEY:
from_secret: chrome_privkey from_secret: chrome_privkey
commands: commands:
- ./pack-browsers.sh - ./pack-chrome.sh
- name: gitea_release - name: gitea_release
image: plugins/gitea-release image: plugins/gitea-release
settings: settings:
@ -15,6 +15,6 @@ steps:
from_secret: gitea_token from_secret: gitea_token
base_url: https://git.purser.it base_url: https://git.purser.it
title: ${DRONE_TAG} title: ${DRONE_TAG}
files: out/proxy-stream-${DRONE_TAG}.crx out/proxy-stream-${DRONE_TAG}.xpi files: out/proxy-stream-${DRONE_TAG}.crx
when: when:
event: tag event: tag

1
.gitignore vendored
View File

@ -11,5 +11,4 @@ android/.gradle/*
android/gradle/* android/gradle/*
chrome/*.png chrome/*.png
*.crx *.crx
*.xpi
sources.json sources.json

View File

@ -7,7 +7,7 @@
"48": "icon-48.png", "48": "icon-48.png",
"128": "icon-128.png" "128": "icon-128.png"
}, },
"version": "111.0", "version": "106.0",
"manifest_version": 3, "manifest_version": 3,
"host_permissions": ["http://127.0.0.1:4000/jsonrpc"], "host_permissions": ["http://127.0.0.1:4000/jsonrpc"],
"permissions": ["tabs"], "permissions": ["tabs"],

View File

@ -4,8 +4,7 @@
<title>Proxy Stream</title> <title>Proxy Stream</title>
</head> </head>
<body> <body>
<button id="proxy-button">Proxy Stream</button> <button>Proxy Stream</button>
<button id="kodi-play-button">Play on kodi</button> <button>Play on kodi</button>
<button id="kodi-queue-button">Queue on kodi</button>
</body> </body>
</html> </html>

View File

@ -5,118 +5,76 @@ providers.set("youtu.be", "youtube")
providers.set("tv.nrk.no", "nrk") providers.set("tv.nrk.no", "nrk")
providers.set("seafile.purser.it", "seafile") providers.set("seafile.purser.it", "seafile")
const random = () => {
const arr = new Uint8Array(32)
window.crypto.getRandomValues(arr)
return [...arr].map(x => x.toString(16).padStart(2, "0")).join("")
}
document.addEventListener("DOMContentLoaded", () => { document.addEventListener("DOMContentLoaded", () => {
const proxyButton = document.getElementById("proxy-button") let [proxyButton, kodiButton] = document.getElementsByTagName("button")
const kodiPlayButton = document.getElementById("kodi-play-button") proxyButton.addEventListener("click", (ev) => {
const kodiQueueButton = document.getElementById("kodi-queue-button") chrome.tabs.query({currentWindow: true, active: true}, (tabs) => {
let oldurl = new URL(tabs[0].url)
async function handleProxyButton(ev) { let newurl = new URL("https://stream.purser.it")
const [tab] = chrome.tabs.query({currentWindow: true, active: true}) let search = new URLSearchParams()
const oldurl = new URL(tab.url) let hostname = oldurl.hostname.toLowerCase()
const search = new URLSearchParams() if(providers.has(hostname)) {
const hostname = oldurl.hostname.toLowerCase() if(hostname.includes("youtube.com")) {
let newurl = new URL("https://stream.purser.it") let newpath = oldurl.searchParams.get("v")
if((newpath instanceof String) || ((typeof newpath) === "string")) {
if(providers.has(hostname)) { newurl.pathname = "/" + newpath
if(hostname.includes("youtube.com")) { }
let newpath = oldurl.searchParams.get("v") } else {
if(newpath) { newurl.pathname = oldurl.pathname
newurl.pathname = "/" + newpath
} }
} else {
newurl.pathname = oldurl.pathname
}
search.append("provider", providers.get(hostname))
} else {
return
}
newurl.search = search.toString()
const newtab = {}
newtab.url = newurl.href
chrome.tabs.create(newtab)
}
async function handleKodiButton(ev, method, playlistid) {
const [tab] = await chrome.tabs.query({currentWindow: true, active: true})
const oldurl = new URL(tab.url)
const search = new URLSearchParams()
const hostname = oldurl.hostname.toLowerCase()
let newurl = new URL("https://stream.purser.it")
if(providers.has(hostname)) {
if(hostname.includes("youtube.com")) {
newurl = new URL("plugin://plugin.video.youtube")
search.append("action", "play_video")
const video_id = oldurl.searchParams.get("v")
if(video_id) {
search.append("videoid", video_id)
}
} else {
search.append("provider", providers.get(hostname)) search.append("provider", providers.get(hostname))
search.append("raw", "true")
newurl.pathname = oldurl.pathname
} }
} else if(hostname == "stream.purser.it") { newurl.search = search.toString()
const provider = oldurl.searchParams.get("provider") let tab = {}
if(provider) { tab.url = newurl.href
if(provider == "youtube") { 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") newurl = new URL("plugin://plugin.video.youtube")
search.append("action", "play_video") search.append("action", "play_video")
const video_id = oldurl.pathname.replace("/", "") let video_id = oldurl.searchParams.get("v")
if(video_id) { if(video_id) {
search.append("videoid", video_id) search.append("videoid", video_id)
} }
} else { } else {
newurl.pathname = oldurl.pathname search.append("provider", providers.get(hostname))
search.append("provider", provider)
search.append("raw", "true") search.append("raw", "true")
newurl.pathname = oldurl.pathname
} }
} }
} else {
return newurl.search = search.toString()
}
let req = {
newurl.search = search.toString() jsonrpc: "2.0",
method: "Player.Open",
const req = { id: 12345,
jsonrpc: "2.0", params: {
method: method, item: {
id: random(), file: newurl.href
params: { }
item: {
file: newurl.href
} }
} }
}
if(playlistid) { try {
req.params.playlistid = playlistid fetch("http://127.0.0.1:4000/jsonrpc", {
} method: "POST",
body: JSON.stringify(req),
const resp = await fetch("http://127.0.0.1:4000/jsonrpc", { headers: {
method: "POST", "Content-Type": "application/json charset=utf-8"
body: JSON.stringify(req), }
headers: { }).then(resp => console.log(resp))
"Content-Type": "application/json; charset=utf-8" } catch(e) {
console.log(e)
} }
}) })
console.log(resp)
}
kodiPlayButton.addEventListener("click", async ev => {
await handleKodiButton(ev, "Player.Open")
}) })
kodiQueueButton.addEventListener("click", async ev => {
await handleKodiButton(ev, "Playlist.Add", 1)
})
proxyButton.addEventListener("click", handleProxyButton)
}) })

View File

@ -36,9 +36,6 @@ then
Xvfb "${DISPLAY}" & Xvfb "${DISPLAY}" &
fi fi
echo "DRONE_TAG=${DRONE_TAG}"
echo "DISPLAY=${DISPLAY}"
${dir}/icons.sh ${dir}/icons.sh
browser=$(which chromium-browser 2> /dev/null) browser=$(which chromium-browser 2> /dev/null)
@ -50,8 +47,6 @@ 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}"
(cd "${release_folder}" && zip -r "${temp_dir}/out/proxy-stream-${DRONE_TAG}.xpi" .)
if grep "/proc/1/cgroup" -q -F -e docker if grep "/proc/1/cgroup" -q -F -e docker
then 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" ${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"