mirror of
https://github.com/leoherzog/TorrentParts.git
synced 2026-01-24 12:18:03 -08:00
Compare commits
38 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1440ac69a1 | ||
|
|
0651975b13 | ||
|
|
a94258296c | ||
|
|
66cb2914a1 | ||
|
|
de3c73f3c1 | ||
|
|
b1794f000b | ||
|
|
013318d258 | ||
|
|
93ef3186f2 | ||
|
|
7d2871abcb | ||
|
|
6e748cde77 | ||
|
|
2c728a61c2 | ||
|
|
7a9aa3bb10 | ||
|
|
aac24cfdd3 | ||
|
|
25eb970141 | ||
|
|
5244cd3710 | ||
|
|
28c2d03f55 | ||
|
|
cda94dd48a | ||
|
|
03c6ae0e17 | ||
|
|
006c8db5e6 | ||
|
|
43f63d8f22 | ||
|
|
9f26fb2384 | ||
|
|
92f5abdb96 | ||
|
|
8813e819c4 | ||
|
|
fa23c0ff3f | ||
|
|
a4152d0542 | ||
|
|
855e4140a0 | ||
|
|
c512101c4e | ||
|
|
e754ee965f | ||
|
|
5298bab66c | ||
|
|
acc6c5ba8c | ||
|
|
b150a2770a | ||
|
|
397d398f36 | ||
|
|
3ad1488a21 | ||
|
|
a47bd05d12 | ||
|
|
3daf51acca | ||
|
|
ad09499db9 | ||
|
|
b14ef98a23 | ||
|
|
85ffd7a9a0 |
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
## What is this?
|
## What is this?
|
||||||
|
|
||||||
[BitTorrent](https://bittorrent.com/) is a ubiquitus and powerful way to transfer files peer-to-peer. To specify what file(s) to download with your client, you need to input either a Torrent file or Magnet URL. [Torrent Parts](https://torrent.parts/) is a client-side static web app to read and edit the metadata of a Torrent file or Magnet URL so you know what you're downloading, before you add it to your Torrent client.
|
[BitTorrent](https://bittorrent.com/) is a ubiquitous and powerful way to transfer files peer-to-peer. To specify what file(s) to download with your client, you need to input either a Torrent file or Magnet URL. [Torrent Parts](https://torrent.parts/) is a client-side static web app to read and edit the metadata of a Torrent file or Magnet URL so you know what you're downloading, before you add it to your Torrent client.
|
||||||
|
|
||||||
### Features
|
### Features
|
||||||
|
|
||||||
@@ -25,7 +25,7 @@ This project wouldn't be possible without the fantastic work of:
|
|||||||
- [@cvisuri](https://github.com/cvisuri), for design work
|
- [@cvisuri](https://github.com/cvisuri), for design work
|
||||||
- [@CorralPeltzer](https://github.com/CorralPeltzer), for [`newTrackon`](https://github.com/CorralPeltzer/newTrackon)
|
- [@CorralPeltzer](https://github.com/CorralPeltzer), for [`newTrackon`](https://github.com/CorralPeltzer/newTrackon)
|
||||||
- [@substack](https://github.com/substack) and contributors, for [`Browserify`](https://github.com/browserify/browserify)
|
- [@substack](https://github.com/substack) and contributors, for [`Browserify`](https://github.com/browserify/browserify)
|
||||||
- [Github Pages](https://pages.github.com/) hosting
|
- [Cloudflare Pages](https://pages.cloudflare.com/) hosting
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
@@ -47,9 +47,6 @@ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|||||||
<a href="https://twitter.com/xd1936" target="_blank">
|
<a href="https://twitter.com/xd1936" target="_blank">
|
||||||
<img src="https://herzog.tech/signature/twitter.svg.png" width="32px" />
|
<img src="https://herzog.tech/signature/twitter.svg.png" width="32px" />
|
||||||
</a>
|
</a>
|
||||||
<a href="https://facebook.com/xd1936" target="_blank">
|
|
||||||
<img src="https://herzog.tech/signature/facebook.svg.png" width="32px" />
|
|
||||||
</a>
|
|
||||||
<a href="https://github.com/leoherzog" target="_blank">
|
<a href="https://github.com/leoherzog" target="_blank">
|
||||||
<img src="https://herzog.tech/signature/github.svg.png" width="32px" />
|
<img src="https://herzog.tech/signature/github.svg.png" width="32px" />
|
||||||
</a>
|
</a>
|
||||||
|
|||||||
32242
bin/bundle.js
32242
bin/bundle.js
File diff suppressed because one or more lines are too long
91
bin/bundle.min.js
vendored
91
bin/bundle.min.js
vendored
File diff suppressed because one or more lines are too long
52
ext/TorrentPartsFASubset.yaml
Normal file
52
ext/TorrentPartsFASubset.yaml
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
projectName: 'C:\Users\Leo\Desktop\TorrentPartsFASubset'
|
||||||
|
version: 6.1.2
|
||||||
|
icons:
|
||||||
|
- magnet:
|
||||||
|
- light
|
||||||
|
- solid
|
||||||
|
- duotone
|
||||||
|
- file-lines:
|
||||||
|
- light
|
||||||
|
- regular
|
||||||
|
- duotone
|
||||||
|
- cloud-arrow-up:
|
||||||
|
- solid
|
||||||
|
- link:
|
||||||
|
- light
|
||||||
|
- duotone
|
||||||
|
- share-nodes:
|
||||||
|
- solid
|
||||||
|
- file-arrow-down:
|
||||||
|
- solid
|
||||||
|
- file:
|
||||||
|
- regular
|
||||||
|
- file-word:
|
||||||
|
- regular
|
||||||
|
- file-powerpoint:
|
||||||
|
- regular
|
||||||
|
- file-excel:
|
||||||
|
- regular
|
||||||
|
- file-zipper:
|
||||||
|
- regular
|
||||||
|
- file-csv:
|
||||||
|
- regular
|
||||||
|
- file-pdf:
|
||||||
|
- regular
|
||||||
|
- file-contract:
|
||||||
|
- regular
|
||||||
|
- file-audio:
|
||||||
|
- regular
|
||||||
|
- file-video:
|
||||||
|
- regular
|
||||||
|
- file-image:
|
||||||
|
- regular
|
||||||
|
- folder-tree:
|
||||||
|
- regular
|
||||||
|
- trash:
|
||||||
|
- regular
|
||||||
|
- xmark:
|
||||||
|
- regular
|
||||||
|
- circle-info:
|
||||||
|
- regular
|
||||||
|
- circle-plus:
|
||||||
|
- regular
|
||||||
5
ext/fa.min.js
vendored
5
ext/fa.min.js
vendored
File diff suppressed because one or more lines are too long
4
ext/notyf.min.js
vendored
4
ext/notyf.min.js
vendored
File diff suppressed because one or more lines are too long
24
index.html
24
index.html
@@ -43,14 +43,6 @@
|
|||||||
<script async defer src="https://buttons.github.io/buttons.js"></script>
|
<script async defer src="https://buttons.github.io/buttons.js"></script>
|
||||||
<script src="/ext/notyf.min.js"></script>
|
<script src="/ext/notyf.min.js"></script>
|
||||||
|
|
||||||
<script async defer src="https://www.googletagmanager.com/gtag/js?id=G-VT4953Z89H"></script>
|
|
||||||
<script>
|
|
||||||
window.dataLayer = window.dataLayer || [];
|
|
||||||
function gtag(){dataLayer.push(arguments);}
|
|
||||||
gtag('js', new Date());
|
|
||||||
gtag('config', 'G-VT4953Z89H');
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script async defer src='https://static.cloudflareinsights.com/beacon.min.js' data-cf-beacon='{"token": "6f97f49b4c384ee197a2f319cebec274"}'></script>
|
<script async defer src='https://static.cloudflareinsights.com/beacon.min.js' data-cf-beacon='{"token": "6f97f49b4c384ee197a2f319cebec274"}'></script>
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
@@ -140,7 +132,7 @@
|
|||||||
<label for="createdBy" style="display:none">Created By</label>
|
<label for="createdBy" style="display:none">Created By</label>
|
||||||
</div>
|
</div>
|
||||||
<div class="content">
|
<div class="content">
|
||||||
<input id="created" type="text" placeholder="Creation time unspecified" aria-label="Creation time" disabled />
|
<input id="created" type="text" placeholder="Creation time unspecified" aria-label="Creation time" disabled required />
|
||||||
<br />
|
<br />
|
||||||
<input id="createdBy" type="text" placeholder="Creation client unspecified" aria-label="Creation client" disabled />
|
<input id="createdBy" type="text" placeholder="Creation client unspecified" aria-label="Creation client" disabled />
|
||||||
</div>
|
</div>
|
||||||
@@ -191,6 +183,18 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="property">
|
||||||
|
<div class="labels">
|
||||||
|
<div>
|
||||||
|
<span class="info" data-tippy-content="Torrents take files and split them into equal size pieces to make them easy to share. Piece size is configurable when a Torrent file is made."><span class="far fa-info-circle"></span></span>
|
||||||
|
<label for="pieces">Pieces</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="content">
|
||||||
|
<input id="pieces" type="text" placeholder="Not included in the URL/File provided" aria-label="Piece size and length" disabled required />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="property">
|
<div class="property">
|
||||||
<div class="labels">
|
<div class="labels">
|
||||||
<div>
|
<div>
|
||||||
@@ -207,7 +211,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<footer>
|
<footer>
|
||||||
<a href="https://github.com/leoherzog/TorrentParts/releases" target="_blank" rel="noopener">v1.1</a>
|
<a href="https://github.com/leoherzog/TorrentParts/releases" target="_blank" rel="noopener">v1.2</a>
|
||||||
</footer>
|
</footer>
|
||||||
|
|
||||||
<script src="/bin/bundle.min.js"></script>
|
<script src="/bin/bundle.min.js"></script>
|
||||||
|
|||||||
30
package.json
30
package.json
@@ -1,34 +1,38 @@
|
|||||||
{
|
{
|
||||||
"name": "torrentparts",
|
"name": "torrentparts",
|
||||||
"version": "1.1",
|
"version": "1.2",
|
||||||
"description": "📑 A website to inspect and edit Torrent files and Magnet URLs",
|
"description": "📑 A website to inspect and edit Torrent files and Magnet URLs",
|
||||||
"main": "bin/bundle.js",
|
"main": "bin/bundle.js",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"browserify": "^17.0.0",
|
"browserify": "^17.0.0",
|
||||||
"bytes": "^3.1.0",
|
"bytes": "^3.1.2",
|
||||||
"clipboard": "^2.0.6",
|
"clipboard": "^2.0.10",
|
||||||
"mime-types": "^2.1.27",
|
"magnet-uri": "^6.2.0",
|
||||||
"parse-torrent": "^9.0.0",
|
"mime-types": "^2.1.35",
|
||||||
"tippy.js": "^6.2.7",
|
"parse-torrent": "^9.1.4",
|
||||||
"webtorrent": "^0.110.1"
|
"tippy.js": "^6.3.7",
|
||||||
|
"webtorrent": "^1.8.6"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"buffer": "^5.2.1",
|
"buffer": "^6.0.3",
|
||||||
"Buffer": "^0.0.0",
|
"notyf": "^3.10.0",
|
||||||
"notyf": "^3.9.0",
|
"terser": "^5.12.1",
|
||||||
"terser": "^5.3.8",
|
"watchify": "^4.0.0"
|
||||||
"watchify": "^3.11.1"
|
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"watch": "watchify src/parse.js -o bin/bundle.js",
|
"watch": "watchify src/parse.js -o bin/bundle.js",
|
||||||
"compile": "browserify src/parse.js -o bin/bundle.js",
|
"compile": "browserify src/parse.js -o bin/bundle.js",
|
||||||
"minify": "terser bin/bundle.js -c -m -o bin/bundle.min.js",
|
"minify": "terser bin/bundle.js -c -m -o bin/bundle.min.js",
|
||||||
"build": "npm run compile && npm run minify"
|
"build": "npm run compile && npm run minify",
|
||||||
|
"update": "npm update -g && npm update && npm run build"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/leoherzog/TorrentParts.git"
|
"url": "https://github.com/leoherzog/TorrentParts.git"
|
||||||
},
|
},
|
||||||
|
"glitch": {
|
||||||
|
"projectType": "generated_static"
|
||||||
|
},
|
||||||
"author": "Leo Herzog",
|
"author": "Leo Herzog",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
|
|||||||
2
robots.txt
Normal file
2
robots.txt
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
User-agent: *
|
||||||
|
Allow: /
|
||||||
218
src/parse.js
218
src/parse.js
@@ -1,6 +1,6 @@
|
|||||||
|
require('buffer');
|
||||||
const clipboard = require('clipboard');
|
const clipboard = require('clipboard');
|
||||||
const parser = require('parse-torrent');
|
const parser = require('parse-torrent');
|
||||||
const Buffer = require('Buffer');
|
|
||||||
const bytes = require('bytes');
|
const bytes = require('bytes');
|
||||||
const mime = require('mime-types');
|
const mime = require('mime-types');
|
||||||
const WebTorrent = require('webtorrent');
|
const WebTorrent = require('webtorrent');
|
||||||
@@ -27,6 +27,7 @@ var announce = document.getElementById('announce');
|
|||||||
var urlList = document.getElementById('urlList');
|
var urlList = document.getElementById('urlList');
|
||||||
var addWebseed = document.getElementById('addWebseed');
|
var addWebseed = document.getElementById('addWebseed');
|
||||||
var removeWebseeds = document.getElementById('removeWebseeds');
|
var removeWebseeds = document.getElementById('removeWebseeds');
|
||||||
|
var pieces = document.getElementById('pieces');
|
||||||
var files = document.getElementById('filesBody');
|
var files = document.getElementById('filesBody');
|
||||||
var getFiles = document.getElementById('getFiles');
|
var getFiles = document.getElementById('getFiles');
|
||||||
var copyURL = document.getElementById('copyURL');
|
var copyURL = document.getElementById('copyURL');
|
||||||
@@ -82,10 +83,10 @@ function start() {
|
|||||||
// magnet input
|
// magnet input
|
||||||
document.getElementById('magnet').addEventListener('keyup', function(event) {
|
document.getElementById('magnet').addEventListener('keyup', function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
if (event.key === "Enter") {
|
if (event.key === 'Enter') {
|
||||||
source = "magnet";
|
source = 'magnet';
|
||||||
originalSourceIcon.innerHTML = '<span class="fad fa-magnet fa-fw"></span>';
|
originalSourceIcon.innerHTML = '<span class="fad fa-magnet fa-fw"></span>';
|
||||||
sourceTooltip.setContent("Currently loaded information sourced from Magnet URL");
|
sourceTooltip.setContent('Currently loaded information sourced from Magnet URL');
|
||||||
parse(magnet.value);
|
parse(magnet.value);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -94,9 +95,9 @@ function start() {
|
|||||||
document.getElementById('torrent').addEventListener('change', function(event) {
|
document.getElementById('torrent').addEventListener('change', function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
event.target.files[0].arrayBuffer().then(function(arrayBuffer) {
|
event.target.files[0].arrayBuffer().then(function(arrayBuffer) {
|
||||||
source = "torrent-file";
|
source = 'torrent-file';
|
||||||
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
||||||
sourceTooltip.setContent("Currently loaded information sourced from Torrent file");
|
sourceTooltip.setContent('Currently loaded information sourced from Torrent file');
|
||||||
parse(Buffer.from(arrayBuffer));
|
parse(Buffer.from(arrayBuffer));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -109,9 +110,9 @@ function start() {
|
|||||||
document.addEventListener('drop', function(event) {
|
document.addEventListener('drop', function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
event.dataTransfer.items[0].getAsFile().arrayBuffer().then(function(arrayBuffer) {
|
event.dataTransfer.items[0].getAsFile().arrayBuffer().then(function(arrayBuffer) {
|
||||||
source = "torrent-file";
|
source = 'torrent-file';
|
||||||
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
||||||
sourceTooltip.setContent("Currently loaded information sourced from Torrent file");
|
sourceTooltip.setContent('Currently loaded information sourced from Torrent file');
|
||||||
parse(Buffer.from(arrayBuffer));
|
parse(Buffer.from(arrayBuffer));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -119,21 +120,30 @@ function start() {
|
|||||||
// example buttons
|
// example buttons
|
||||||
example1.addEventListener('click', function(event) {
|
example1.addEventListener('click', function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
notyf.success("Parsing Ubuntu 20.04 Magnet URL");
|
notyf.success('Parsing Ubuntu 22.04 Magnet URL');
|
||||||
parse("magnet:?xt=urn:btih:9fc20b9e98ea98b4a35e6223041a5ef94ea27809&dn=ubuntu-20.04-desktop-amd64.iso&tr=https%3A%2F%2Ftorrent.ubuntu.com%2Fannounce&tr=https%3A%2F%2Fipv6.torrent.ubuntu.com%2Fannounce");
|
source = 'magnet';
|
||||||
|
originalSourceIcon.innerHTML = '<span class="fad fa-magnet fa-fw"></span>';
|
||||||
|
sourceTooltip.setContent('Currently loaded information sourced from Magnet URL');
|
||||||
|
parse('magnet:?xt=urn:btih:2c6b6858d61da9543d4231a71db4b1c9264b0685&dn=ubuntu-22.04-desktop-amd64.iso&tr=https%3A%2F%2Ftorrent.ubuntu.com%2Fannounce&tr=https%3A%2F%2Fipv6.torrent.ubuntu.com%2Fannounce');
|
||||||
});
|
});
|
||||||
|
|
||||||
example2.addEventListener('click', async function(event) {
|
example2.addEventListener('click', async function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
notyf.success("Fetching and Parsing “The WIRED CD” Torrent File...");
|
notyf.success('Fetching and Parsing “The WIRED CD” Torrent File...');
|
||||||
parseRemote("https://webtorrent.io/torrents/wired-cd.torrent");
|
source = 'remote-torrent-file';
|
||||||
|
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
||||||
|
sourceTooltip.setContent('Currently loaded information sourced from remotely fetched Torrent file');
|
||||||
|
parseRemote('https://webtorrent.io/torrents/wired-cd.torrent');
|
||||||
});
|
});
|
||||||
|
|
||||||
example3.addEventListener('click', async function(event) {
|
example3.addEventListener('click', async function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
notyf.success("Parsing Jack Johnson Archive.org Torrent File");
|
notyf.success('Parsing Jack Johnson Archive.org Torrent File');
|
||||||
let response = await fetch("/ext/jj2008-06-14.mk4_archive.torrent");
|
let response = await fetch('/ext/jj2008-06-14.mk4_archive.torrent');
|
||||||
let arrayBuffer = await response.arrayBuffer();
|
let arrayBuffer = await response.arrayBuffer();
|
||||||
|
source = 'torrent-file';
|
||||||
|
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
||||||
|
sourceTooltip.setContent('Currently loaded information sourced from Torrent file');
|
||||||
parse(Buffer.from(arrayBuffer));
|
parse(Buffer.from(arrayBuffer));
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -142,10 +152,6 @@ function start() {
|
|||||||
copyurl.on('success', function(e) {
|
copyurl.on('success', function(e) {
|
||||||
notyf.success('Copied site URL to clipboard!');
|
notyf.success('Copied site URL to clipboard!');
|
||||||
console.info(e);
|
console.info(e);
|
||||||
gtag('event', 'share', {
|
|
||||||
"method": "Copy URL",
|
|
||||||
"content_id": e.text,
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
copyurl.on('failure', function(e) {
|
copyurl.on('failure', function(e) {
|
||||||
notyf.error('Problem copying to clipboard');
|
notyf.error('Problem copying to clipboard');
|
||||||
@@ -155,10 +161,6 @@ function start() {
|
|||||||
let copymagnet = new clipboard('#copyMagnet');
|
let copymagnet = new clipboard('#copyMagnet');
|
||||||
copymagnet.on('success', function(e) {
|
copymagnet.on('success', function(e) {
|
||||||
notyf.success('Copied Magnet URL to clipboard!');
|
notyf.success('Copied Magnet URL to clipboard!');
|
||||||
gtag('event', 'share', {
|
|
||||||
"method": "Copy Magnet",
|
|
||||||
"content_id": e.text,
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
copymagnet.on('failure', function(e) {
|
copymagnet.on('failure', function(e) {
|
||||||
notyf.error('Problem copying to clipboard');
|
notyf.error('Problem copying to clipboard');
|
||||||
@@ -186,9 +188,9 @@ function start() {
|
|||||||
sourceTooltip.disable();
|
sourceTooltip.disable();
|
||||||
|
|
||||||
if (window.location.hash) {
|
if (window.location.hash) {
|
||||||
source = "shared-url";
|
source = 'shared-url';
|
||||||
originalSourceIcon.innerHTML = '<span class="fad fa-link fa-fw"></span>';
|
originalSourceIcon.innerHTML = '<span class="fad fa-link fa-fw"></span>';
|
||||||
sourceTooltip.setContent("Currently loaded information sourced from shared torrent.parts link");
|
sourceTooltip.setContent('Currently loaded information sourced from shared torrent.parts link');
|
||||||
parse(window.location.hash.split('#')[1]);
|
parse(window.location.hash.split('#')[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -197,18 +199,18 @@ function start() {
|
|||||||
function parse(toLoad) {
|
function parse(toLoad) {
|
||||||
resetProperties();
|
resetProperties();
|
||||||
try {
|
try {
|
||||||
console.info("Attempting parse");
|
console.info('Attempting parse');
|
||||||
parsed = parser(toLoad);
|
parsed = parser(toLoad);
|
||||||
display();
|
display();
|
||||||
if (parsed.xs) {
|
if (parsed.xs) {
|
||||||
console.info("Magnet includes xs, attempting remote parse");
|
console.info('Magnet includes xs, attempting remote parse');
|
||||||
parseRemote(parsed.xs);
|
parseRemote(parsed.xs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(e) { // maybe they put a URL to a torrent file in the magnet box?
|
catch(e) { // maybe they put a URL to a torrent file in the magnet box?
|
||||||
console.warn(e);
|
console.warn(e);
|
||||||
if (source == "magnet") {
|
if (source == 'magnet') {
|
||||||
console.info("Attempting remote parse");
|
console.info('Attempting remote parse');
|
||||||
parseRemote(toLoad);
|
parseRemote(toLoad);
|
||||||
} else { // probably not. Just a bad file.
|
} else { // probably not. Just a bad file.
|
||||||
notyf.error('Problem parsing input. Is this a .torrent file?');
|
notyf.error('Problem parsing input. Is this a .torrent file?');
|
||||||
@@ -225,9 +227,9 @@ function parseRemote(toLoad) {
|
|||||||
resetProperties();
|
resetProperties();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
source = "remote-torrent-file";
|
source = 'remote-torrent-file';
|
||||||
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
originalSourceIcon.innerHTML = '<span class="fad fa-file-alt fa-fw"></span>';
|
||||||
sourceTooltip.setContent("Currently loaded information sourced from remotely fetched Torrent file");
|
sourceTooltip.setContent('Currently loaded information sourced from remotely fetched Torrent file');
|
||||||
parsed = result;
|
parsed = result;
|
||||||
display();
|
display();
|
||||||
});
|
});
|
||||||
@@ -238,17 +240,18 @@ function display() {
|
|||||||
console.log(parsed);
|
console.log(parsed);
|
||||||
|
|
||||||
hash.value = parsed.infoHash;
|
hash.value = parsed.infoHash;
|
||||||
name.value = parsed.name ? parsed.name : "";
|
name.value = parsed.name ? parsed.name : '';
|
||||||
if (parsed.created) {
|
if (parsed.created) {
|
||||||
created.value = parsed.created.toISOString().slice(0, 19);
|
created.value = parsed.created.toISOString().slice(0, 19);
|
||||||
created.type = "datetime-local";
|
created.type = 'datetime-local';
|
||||||
} else {
|
} else {
|
||||||
created.type = "text";
|
created.type = 'text';
|
||||||
}
|
}
|
||||||
createdBy.value = parsed.createdBy ? "by " + parsed.createdBy : "";
|
createdBy.value = parsed.createdBy ? ' by ' + parsed.createdBy : '';
|
||||||
comment.value = parsed.comment ? parsed.comment : "";
|
comment.value = parsed.comment ? parsed.comment : '';
|
||||||
|
pieces.value = parsed.pieces ? parsed.pieces.length.toLocaleString() + ' ' + bytes.format(parsed.pieceLength, {"decimalPlaces": 1, "unitSeparator": " "}) + ' pieces (last piece ' + bytes.format(parsed.lastPieceLength, {"decimalPlaces": 1, "unitSeparator": " "}) + ')' : '';
|
||||||
|
|
||||||
announce.innerHTML = "";
|
announce.innerHTML = '';
|
||||||
if (parsed.announce && parsed.announce.length) {
|
if (parsed.announce && parsed.announce.length) {
|
||||||
for (let i = 0; i < parsed.announce.length; i++) {
|
for (let i = 0; i < parsed.announce.length; i++) {
|
||||||
let row = document.createElement('div');
|
let row = document.createElement('div');
|
||||||
@@ -271,10 +274,10 @@ function display() {
|
|||||||
announce.appendChild(row);
|
announce.appendChild(row);
|
||||||
}
|
}
|
||||||
// } else {
|
// } else {
|
||||||
// announce.innerHTML = "<em>No trackers specified in the URL/File provided</em>";
|
// announce.innerHTML = '<em>No trackers specified in the URL/File provided</em>';
|
||||||
}
|
}
|
||||||
|
|
||||||
urlList.innerHTML = "";
|
urlList.innerHTML = '';
|
||||||
if (parsed.urlList && parsed.urlList.length) {
|
if (parsed.urlList && parsed.urlList.length) {
|
||||||
for (let i = 0; i < parsed.urlList.length; i++) {
|
for (let i = 0; i < parsed.urlList.length; i++) {
|
||||||
let row = document.createElement('div');
|
let row = document.createElement('div');
|
||||||
@@ -297,12 +300,12 @@ function display() {
|
|||||||
urlList.appendChild(row);
|
urlList.appendChild(row);
|
||||||
}
|
}
|
||||||
// } else {
|
// } else {
|
||||||
// urlList.innerHTML = "<em>No webseed URLs in the URL/File provided</em>";
|
// urlList.innerHTML = '<em>No webseed URLs in the URL/File provided</em>';
|
||||||
}
|
}
|
||||||
|
|
||||||
files.innerHTML = "";
|
files.innerHTML = '';
|
||||||
if (parsed.files && parsed.files.length) {
|
if (parsed.files && parsed.files.length) {
|
||||||
getFiles.style.display = "none";
|
getFiles.style.display = 'none';
|
||||||
if (parsed.files.length < 100) {
|
if (parsed.files.length < 100) {
|
||||||
for (let file of parsed.files) {
|
for (let file of parsed.files) {
|
||||||
let icon = getFontAwesomeIconForMimetype(mime.lookup(file.name));
|
let icon = getFontAwesomeIconForMimetype(mime.lookup(file.name));
|
||||||
@@ -321,10 +324,10 @@ function display() {
|
|||||||
downloadTorrent.disabled = false;
|
downloadTorrent.disabled = false;
|
||||||
} else {
|
} else {
|
||||||
if (client.torrents.length > 0) {
|
if (client.torrents.length > 0) {
|
||||||
getFiles.style.display = "none";
|
getFiles.style.display = 'none';
|
||||||
files.innerHTML = '<input type="text" placeholder="Attempting fetching of files from Webtorrent..." aria-label="Attempting fetching of files from Webtorrent..." disabled>';
|
files.innerHTML = '<input type="text" placeholder="Attempting fetching of files from Webtorrent..." aria-label="Attempting fetching of files from Webtorrent..." disabled>';
|
||||||
} else {
|
} else {
|
||||||
getFiles.style.display = "block";
|
getFiles.style.display = 'block';
|
||||||
files.innerHTML = '<input type="text" placeholder="Not included in the URL/File provided" aria-label="Files information not included in the URL/File provided" disabled>';
|
files.innerHTML = '<input type="text" placeholder="Not included in the URL/File provided" aria-label="Files information not included in the URL/File provided" disabled>';
|
||||||
}
|
}
|
||||||
downloadTorrentTooltip.setContent('Files metadata is required to generate a Torrent file. Try fetching files list from WebTorrent.');
|
downloadTorrentTooltip.setContent('Files metadata is required to generate a Torrent file. Try fetching files list from WebTorrent.');
|
||||||
@@ -332,7 +335,7 @@ function display() {
|
|||||||
downloadTorrent.disabled = true;
|
downloadTorrent.disabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
copyURL.setAttribute('data-clipboard-text', window.location.origin + "#" + parser.toMagnetURI(parsed));
|
copyURL.setAttribute('data-clipboard-text', window.location.origin + '#' + parser.toMagnetURI(parsed));
|
||||||
copyMagnet.setAttribute('data-clipboard-text', parser.toMagnetURI(parsed));
|
copyMagnet.setAttribute('data-clipboard-text', parser.toMagnetURI(parsed));
|
||||||
|
|
||||||
examples.style.display = 'none';
|
examples.style.display = 'none';
|
||||||
@@ -341,21 +344,13 @@ function display() {
|
|||||||
window.location.hash = parser.toMagnetURI(parsed);
|
window.location.hash = parser.toMagnetURI(parsed);
|
||||||
|
|
||||||
if (parsed.name) {
|
if (parsed.name) {
|
||||||
document.title = "Torrent Parts | " + parsed.name;
|
document.title = 'Torrent Parts | ' + parsed.name;
|
||||||
} else {
|
} else {
|
||||||
document.title = "Torrent Parts | Inspect and edit what's in your Torrent file or Magnet link";
|
document.title = 'Torrent Parts | Inspect and edit what\'s in your Torrent file or Magnet link';
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceTooltip.enable();
|
sourceTooltip.enable();
|
||||||
|
|
||||||
gtag('event', 'view_item', {
|
|
||||||
items: [{
|
|
||||||
"item_id": parsed.infoHash,
|
|
||||||
"item_name": parsed.name,
|
|
||||||
"item_category": source
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function createFileRow(icon, name, size) {
|
function createFileRow(icon, name, size) {
|
||||||
@@ -375,37 +370,37 @@ function createFileRow(icon, name, size) {
|
|||||||
function getFontAwesomeIconForMimetype(mimetype) {
|
function getFontAwesomeIconForMimetype(mimetype) {
|
||||||
if (!mimetype) return 'file';
|
if (!mimetype) return 'file';
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case mimetype.includes("msword"):
|
case mimetype.includes('msword'):
|
||||||
case mimetype.includes("wordprocessingml"):
|
case mimetype.includes('wordprocessingml'):
|
||||||
case mimetype.includes("opendocument.text"):
|
case mimetype.includes('opendocument.text'):
|
||||||
case mimetype.includes("abiword"):
|
case mimetype.includes('abiword'):
|
||||||
return 'file-word';
|
return 'file-word';
|
||||||
case mimetype.includes("ms-excel"):
|
case mimetype.includes('ms-excel'):
|
||||||
case mimetype.includes("spreadsheet"):
|
case mimetype.includes('spreadsheet'):
|
||||||
return 'file-powerpoint';
|
return 'file-powerpoint';
|
||||||
case mimetype.includes("powerpoint"):
|
case mimetype.includes('powerpoint'):
|
||||||
case mimetype.includes("presentation"):
|
case mimetype.includes('presentation'):
|
||||||
return 'file-powerpoint';
|
return 'file-powerpoint';
|
||||||
case mimetype.includes("7z-"):
|
case mimetype.includes('7z-'):
|
||||||
case mimetype.includes("iso9660"):
|
case mimetype.includes('iso9660'):
|
||||||
case mimetype.includes("zip"):
|
case mimetype.includes('zip'):
|
||||||
case mimetype.includes("octet-stream"):
|
case mimetype.includes('octet-stream'):
|
||||||
return 'file-archive';
|
return 'file-archive';
|
||||||
case mimetype.includes("csv"):
|
case mimetype.includes('csv'):
|
||||||
return 'file-csv';
|
return 'file-csv';
|
||||||
case mimetype.includes("pdf"):
|
case mimetype.includes('pdf'):
|
||||||
return 'file-pdf';
|
return 'file-pdf';
|
||||||
case mimetype.includes("font"):
|
case mimetype.includes('font'):
|
||||||
return 'file-contract';
|
return 'file-contract';
|
||||||
case mimetype.includes("text"):
|
case mimetype.includes('text'):
|
||||||
case mimetype.includes("subrip"):
|
case mimetype.includes('subrip'):
|
||||||
case mimetype.includes("vtt"):
|
case mimetype.includes('vtt'):
|
||||||
return 'file-alt';
|
return 'file-alt';
|
||||||
case mimetype.includes("audio"):
|
case mimetype.includes('audio'):
|
||||||
return 'file-audio';
|
return 'file-audio';
|
||||||
case mimetype.includes("image"):
|
case mimetype.includes('image'):
|
||||||
return 'file-image';
|
return 'file-image';
|
||||||
case mimetype.includes("video"):
|
case mimetype.includes('video'):
|
||||||
return 'file-video';
|
return 'file-video';
|
||||||
default:
|
default:
|
||||||
return 'file';
|
return 'file';
|
||||||
@@ -414,46 +409,45 @@ function getFontAwesomeIconForMimetype(mimetype) {
|
|||||||
|
|
||||||
function propertyChange(e) {
|
function propertyChange(e) {
|
||||||
if (this.dataset.group) {
|
if (this.dataset.group) {
|
||||||
parsed[this.dataset.group][this.dataset.index] = this.value ? this.value : "";
|
parsed[this.dataset.group][this.dataset.index] = this.value ? this.value : '';
|
||||||
} else {
|
} else {
|
||||||
parsed[this.id] = this.value ? this.value : "";
|
parsed[this.id] = this.value ? this.value : '';
|
||||||
}
|
}
|
||||||
window.location.hash = parser.toMagnetURI(parsed);
|
window.location.hash = parser.toMagnetURI(parsed);
|
||||||
updateModified();
|
updateModified();
|
||||||
}
|
}
|
||||||
|
|
||||||
function resetProperties() {
|
function resetProperties() {
|
||||||
document.getElementById('magnet').value = "";
|
document.getElementById('magnet').value = '';
|
||||||
document.getElementById('torrent').value = "";
|
document.getElementById('torrent').value = '';
|
||||||
examples.style.display = 'flex';
|
examples.style.display = 'flex';
|
||||||
properties.style.display = 'none';
|
properties.style.display = 'none';
|
||||||
name.value = "";
|
name.value = '';
|
||||||
created.value = "";
|
created.value = '';
|
||||||
createdBy.value = "";
|
createdBy.value = '';
|
||||||
comment.value = "";
|
comment.value = '';
|
||||||
hash.value = "";
|
hash.value = '';
|
||||||
announce.innerHTML = "";
|
announce.innerHTML = '';
|
||||||
urlList.innerHTML = "";
|
urlList.innerHTML = '';
|
||||||
client.torrents.forEach(torrent => torrent.destroy());
|
client.torrents.forEach(torrent => torrent.destroy());
|
||||||
getFiles.style.display = "block";
|
getFiles.style.display = 'block';
|
||||||
files.innerHTML = "";
|
files.innerHTML = '';
|
||||||
window.location.hash = "";
|
window.location.hash = '';
|
||||||
copyURL.setAttribute('data-clipboard-text', "");
|
copyURL.setAttribute('data-clipboard-text', '');
|
||||||
copyMagnet.setAttribute('data-clipboard-text', "");
|
copyMagnet.setAttribute('data-clipboard-text', '');
|
||||||
document.title = "Torrent Parts | Inspect and edit what's in your Torrent file or Magnet link";
|
document.title = 'Torrent Parts | Inspect and edit what\'s in your Torrent file or Magnet link';
|
||||||
sourceTooltip.disable();
|
sourceTooltip.disable();
|
||||||
gtag('event', 'reset');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function addCurrentTrackers() {
|
async function addCurrentTrackers() {
|
||||||
addTrackers.className = 'disabled';
|
addTrackers.className = 'disabled';
|
||||||
addTrackers.innerHTML = 'Adding...';
|
addTrackers.innerHTML = 'Adding...';
|
||||||
try {
|
try {
|
||||||
let response = await fetch("https://newtrackon.com/api/100"); // get trackers with 100% uptime
|
let response = await fetch('https://newtrackon.com/api/stable'); // get trackers with 95% uptime
|
||||||
let trackers = await response.text();
|
let trackers = await response.text();
|
||||||
parsed.announce = parsed.announce.concat(trackers.split('\n\n'));
|
parsed.announce = parsed.announce.concat(trackers.split('\n\n'));
|
||||||
parsed.announce.push("http://bt1.archive.org:6969/announce");
|
parsed.announce.push('http://bt1.archive.org:6969/announce');
|
||||||
parsed.announce.push("http://bt2.archive.org:6969/announce");
|
parsed.announce.push('http://bt2.archive.org:6969/announce');
|
||||||
parsed.announce = parsed.announce.filter((v,i) => v && parsed.announce.indexOf(v) === i); // remove duplicates and empties
|
parsed.announce = parsed.announce.filter((v,i) => v && parsed.announce.indexOf(v) === i); // remove duplicates and empties
|
||||||
notyf.success('Added known working trackers from newTrackon');
|
notyf.success('Added known working trackers from newTrackon');
|
||||||
updateModified();
|
updateModified();
|
||||||
@@ -465,11 +459,10 @@ async function addCurrentTrackers() {
|
|||||||
addTrackers.className = '';
|
addTrackers.className = '';
|
||||||
addTrackers.innerHTML = 'Add Known Working Trackers';
|
addTrackers.innerHTML = 'Add Known Working Trackers';
|
||||||
display();
|
display();
|
||||||
gtag('event', 'add_trackers');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function addRow() {
|
function addRow() {
|
||||||
parsed[this.dataset.type].unshift("");
|
parsed[this.dataset.type].unshift('');
|
||||||
display();
|
display();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -486,23 +479,23 @@ function removeAllRows(type) {
|
|||||||
|
|
||||||
function updateModified() {
|
function updateModified() {
|
||||||
parsed.created = new Date();
|
parsed.created = new Date();
|
||||||
parsed.createdBy = "Torrent Parts <https://torrent.parts/>";
|
parsed.createdBy = 'Torrent Parts <https://torrent.parts/>';
|
||||||
if (parsed.created) {
|
if (parsed.created) {
|
||||||
created.value = parsed.created.toISOString().slice(0, 19);
|
created.value = parsed.created.toISOString().slice(0, 19);
|
||||||
created.type = "datetime-local";
|
created.type = 'datetime-local';
|
||||||
} else {
|
} else {
|
||||||
created.type = "text";
|
created.type = 'text';
|
||||||
}
|
}
|
||||||
createdBy.value = parsed.createdBy ? "by " + parsed.createdBy : "";
|
createdBy.value = parsed.createdBy ? ' by ' + parsed.createdBy : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
function getFilesFromPeers() {
|
function getFilesFromPeers() {
|
||||||
console.info("Attempting fetching files from Webtorrent...");
|
console.info('Attempting fetching files from Webtorrent...');
|
||||||
getFiles.style.display = "none";
|
getFiles.style.display = 'none';
|
||||||
parsed.announce.push("wss://tracker.webtorrent.io");
|
parsed.announce.push('wss://tracker.webtorrent.io');
|
||||||
parsed.announce.push("wss://tracker.openwebtorrent.com");
|
parsed.announce.push('wss://tracker.openwebtorrent.com');
|
||||||
parsed.announce.push("wss://tracker.btorrent.xyz");
|
parsed.announce.push('wss://tracker.btorrent.xyz');
|
||||||
parsed.announce.push("wss://tracker.fastcast.nz");
|
parsed.announce.push('wss://tracker.fastcast.nz');
|
||||||
parsed.announce = parsed.announce.filter((v,i) => v && parsed.announce.indexOf(v) === i); // remove duplicates and empties
|
parsed.announce = parsed.announce.filter((v,i) => v && parsed.announce.indexOf(v) === i); // remove duplicates and empties
|
||||||
client.add(parser.toMagnetURI(parsed), (torrent) => {
|
client.add(parser.toMagnetURI(parsed), (torrent) => {
|
||||||
parsed.info = Object.assign({}, torrent.info); // clone object
|
parsed.info = Object.assign({}, torrent.info); // clone object
|
||||||
@@ -516,7 +509,6 @@ function getFilesFromPeers() {
|
|||||||
torrent.destroy();
|
torrent.destroy();
|
||||||
});
|
});
|
||||||
display();
|
display();
|
||||||
gtag('event', 'attempt_webtorrent_fetch');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://stackoverflow.com/a/36899900/2700296
|
// https://stackoverflow.com/a/36899900/2700296
|
||||||
@@ -527,14 +519,10 @@ function saveTorrent() {
|
|||||||
let a = document.createElement('a');
|
let a = document.createElement('a');
|
||||||
a.style.display = 'none';
|
a.style.display = 'none';
|
||||||
let url = window.URL.createObjectURL(new Blob([data], { "type": "application/x-bittorrent" }));
|
let url = window.URL.createObjectURL(new Blob([data], { "type": "application/x-bittorrent" }));
|
||||||
a.setAttribute("href", url);
|
a.setAttribute('href', url);
|
||||||
a.setAttribute("download", parsed.name + '.torrent');
|
a.setAttribute('download', parsed.name + '.torrent');
|
||||||
document.body.appendChild(a);
|
document.body.appendChild(a);
|
||||||
a.click();
|
a.click();
|
||||||
window.URL.revokeObjectURL(url);
|
window.URL.revokeObjectURL(url);
|
||||||
a.remove();
|
a.remove();
|
||||||
gtag('event', 'share', {
|
|
||||||
"method": "Torrent Download",
|
|
||||||
"content_id": parsed.name
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user