Compare commits
No commits in common. "master" and "v106" have entirely different histories.
@ -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
1
.gitignore
vendored
@ -11,5 +11,4 @@ android/.gradle/*
|
|||||||
android/gradle/*
|
android/gradle/*
|
||||||
chrome/*.png
|
chrome/*.png
|
||||||
*.crx
|
*.crx
|
||||||
*.xpi
|
|
||||||
sources.json
|
sources.json
|
||||||
|
@ -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"],
|
||||||
|
@ -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>
|
||||||
|
144
chrome/script.js
144
chrome/script.js
@ -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()
|
newurl.search = search.toString()
|
||||||
|
|
||||||
const req = {
|
let req = {
|
||||||
jsonrpc: "2.0",
|
jsonrpc: "2.0",
|
||||||
method: method,
|
method: "Player.Open",
|
||||||
id: random(),
|
id: 12345,
|
||||||
params: {
|
params: {
|
||||||
item: {
|
item: {
|
||||||
file: newurl.href
|
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)
|
|
||||||
})
|
})
|
||||||
|
@ -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"
|
Loading…
Reference in New Issue
Block a user