-
Download specific installer files from the GitHub releases page.
-
Try the (unstable) development version by cloning the Git repository. See the "How to Contribute" instructions.
The difference between this torrent client and many others including the same WebTorrent is that this app is specially for music. Creating, modifying and share your playlists, with torrents now is possible.
Giving the chance to the people of modern ways of sharing culture in a easy way without restrictions.
I created a format for this playlists in JSON, to keep it easy and not get confused with other kind of playlists the name of this kind of list is Refreex Playlist
The Refreex Playlists are created in JSON format like this:
{
"id": "NameOfThePlaylist",
"torrents": [
{
"infoHash": "a80fda124873fa7d93937d9c607f206e00559269",
"files": [
"Dexter_Britain_-_03_-_In_The_Electric_Fields.mp3",
"Dexter_Britain_-_01_-_The_Time_To_Run_Finale.ogg"
]
},
{
"infoHash": "4b53bd8f85a653adcc9cc66aaa7500b946ab06b9",
"files": [
"Cloudkicker_-_10_-_You_and_yours.ogg",
"Cloudkicker_-_10_-_You_and_yours.mp3",
"NeZoomie_-_04_-_Heavy_Phat_Gun.mp3"
]
},
{
"infoHash": "1c4bfb44845f584fc0cf343edb4fc67bc177bb1b",
"files": [
"art_of_war_01-02_sun_tzu.mp3"
]
},
{
"infoHash": "a88fda5954e89178c372716a6a78b8180ed4dad3",
"files": [
"05 - Spoon - Revenge!.mp3",
"16 - Matmos - Action At A Distance.mp3"
]
}
]
}
As we can see the idea is simple but effective. The Refreex Playlist (JSON) has just two properties.
-
The first one is
id
this one must be unique and we cannot have two Refreex Playlist with the sameid
in the Refreex App. Is the name of the playlist. -
The second one is
torrents
this one is an array of objects. Those objects are the torrents indeed and they are composed by two properties theinfoHash
of a torrent (you can get it from the magnet link) and thefiles
that you want to add to the playlist
For the future / ideas:
We can share at the moment the playlists in plain text, json files and the app will know how to read it parse it and download it.
I been thinking for the future that the Refreex Playlists
should be created using DAT protocol to allow mutation of the playlist (torrents are immutables).
$ git clone https://github.com/refreex/refreex-webtorrent-desktop.git
$ cd refreex-webtorrent-desktop
$ npm install
$ npm start
Restart the app automatically every time code changes. Useful during development.
$ npm run watch
$ npm test
$ npm run test-integration
The integration tests use Spectron and Tape. They click through the app, taking screenshots and comparing each one to a reference. Why screenshots?
- Ad-hoc checking makes the tests a lot more work to write
- Even diffing the whole HTML is not as thorough as screenshot diffing. For example, it wouldn't catch an bug where hitting ESC from a video doesn't correctly restore window size.
- Chrome's own integration tests use screenshot diffing iirc
- Small UI changes will break a few tests, but the fix is as easy as deleting the offending screenshots and running the tests, which will recreate them with the new look.
- The resulting Github PR will then show, pixel by pixel, the exact UI changes that were made! See https://github.com/blog/817-behold-image-view-modes
For MacOS, you'll need a Retina screen for the integration tests to pass. Your screen should have the same resolution as a 2016 12" Macbook.
For Windows, you'll need Windows 10 with a 1366x768 screen.
When running integration tests, keep the mouse on the edge of the screen and don't touch the mouse or keyboard while the tests are running.
Builds app binaries for Mac, Linux, and Windows.
$ npm run package
To build for one platform:
$ npm run package -- [platform] [options]
Where [platform]
is darwin
, linux
, win32
, or all
(default).
The following optional arguments are available:
--sign
- Sign the application (Mac, Windows)--package=[type]
- Package single output type.deb
- Debian packagezip
- Linux zip filedmg
- Mac disk imageexe
- Windows installerportable
- Windows portable appall
- All platforms (default)
Note: Even with the --package
option, the auto-update files (.nupkg for Windows,
-darwin.zip for Mac) will always be produced.
The Windows app can be packaged from any platform.
Note: Windows code signing only works from Windows, for now.
Note: To package the Windows app from non-Windows platforms, Wine and Mono need to be installed. For example on Mac, first install XQuartz, then run:
brew install wine mono
(Requires the Homebrew package manager.)
The Mac app can only be packaged from macOS.
The Linux app can be packaged from any platform.
If packaging from Mac, install system dependencies with Homebrew by running:
npm run install-system-deps
Electron (Framework to make native apps for Windows, OSX and Linux in Javascript): https://electronjs.org/docs/tutorial/quick-start
React.js (Framework to work with Frontend UI): https://reactjs.org/docs/getting-started.html
Material UI (React components that implement Google's Material Design.): https://material-ui.com/getting-started https://material.io/tools/icons/?style=baseline
WebTorrent Desktop collects some basic usage stats to help us make the app better. For example, we track how well the play button works. How often does it succeed? Time out? Show a missing codec error?
The app never sends any personally identifying information, nor does it track which torrents you add.
MIT. Copyright (c) WebTorrent, LLC.