Node.JS Server and JavaScript/HTML Client for synchronizing online media
Go to file
Calvin Montgomery 6d0498987a Add sanity check for one instance of error unload
Unfortunately I think this is just one of a whole class of race
conditions caused by errored channels being unloaded immediately without
waiting for the refcounter to reach 0.

However, this one is the only one that appears commonly in the logs so
adding this check should buy time to rethink the overall problem.
2018-01-06 10:09:22 -08:00
conf/example Update password reset to use new nodemailer impl 2017-09-26 21:22:15 -07:00
docs custom-media: import spec and fix a minor missed validation 2017-08-08 20:46:10 -07:00
gdrive-userscript Clarify gdrive userscript error when fmt_stream_map is missing 2017-12-26 20:40:12 -08:00
integration_test Start working on /account/data controller 2017-08-30 22:45:48 -07:00
player Replace froogaloop 2017-10-28 23:10:15 -07:00
src Add sanity check for one instance of error unload 2018-01-06 10:09:22 -08:00
templates Replace froogaloop 2017-10-28 23:10:15 -07:00
test Use socket.handshake instead of socket.client.request 2017-12-27 14:24:33 -08:00
www Clarify gdrive userscript error when fmt_stream_map is missing 2017-12-26 20:40:12 -08:00
.gitignore Generate .meta.js for gdrive userscript for update checks 2017-08-19 16:31:02 -07:00
.travis.yml Add node.js 9 to .travis.yml 2017-12-27 14:24:57 -08:00
build-player.js Implement playerjs for streamable (#706) 2017-09-25 19:18:46 -07:00
config.template.yaml Remove config option that is no longer used 2017-12-26 11:00:18 -08:00
index.js Refactor index.js logic into src/main 2017-08-13 22:16:42 -07:00
ISSUE_TEMPLATE.md Create ISSUE_TEMPLATE.md 2016-02-17 19:38:47 -08:00
LICENSE 2016 -> 2017 2017-01-05 23:05:09 -08:00
NEWS.md Add NEWS.md update I forgot to commit 2017-12-26 11:04:40 -08:00
package.json Fix errored channels getting stuck during unload 2018-01-06 09:59:18 -08:00
postinstall.sh Instead, add env var for overriding user input 2017-03-21 20:27:29 -07:00
README.md Update README.md 2015-08-16 13:31:34 -07:00
run.sh Refactor out server init to index.js 2013-10-11 15:48:01 -05:00
servcmd.sh.js Add support for v8-profiler (optional dep) 2017-09-18 21:54:36 -07:00

Read before submitting an issue: https://github.com/calzoneman/sync/wiki/Reporting-an-Issue

calzoneman/sync

About

CyTube is a web application providing media synchronization, chat, and more for an arbitrary number of channels. I began developing this as a hobby project, and when synchtube.com announced their closure, I began polishing it and readying it for the public.

I am hosting a CyTube server at http://cytu.be

The serverside is written in JavaScript and runs on Node.JS. It makes use of a MySQL database to store user registrations, cached media metadata, and data about each channel.

The clientside is written in JavaScript and makes use of Socket.IO and jQuery as well as the APIs for various media providers. The web interface uses Bootstrap for layout and styling.

Features

  • Standalone web/socket.io server
  • Optional SSL support for socket.io and the account API
  • Synchronized playback from the following sources:
    • YouTube (individual videos + playlists)
    • Google Docs videos
    • Vimeo
    • Dailymotion
    • Soundcloud
    • Raw video/audio files (via video.js)
  • Embedding of the following sources:
    • livestream.com
    • twitch.tv
    • justin.tv
    • ustream.tv
    • RTMP streams
    • Custom <iframe> and <object> embeds
  • Channel customization
    • HTML Message of the Day
    • CSS
    • JavaScript
    • Permissions
      • Tiered ranks (Site admin > Channel admin > Moderator > Leader > Member > Guest > Anonymous)
    • Chat filters (based on regular expressions)
    • Lock/unlock playlist to allow additions by non-moderators (configurable with permissions)
    • Searchable library of videos
  • Integrated YouTube search
  • Save/load playlists per user account
  • Polls
  • Voteskip (can be disabled by a channel moderator)
  • Auto-AFK status (can be configured per-channel)
  • Leader
    • Grants control of playback to a user (can pause/seek)
    • Can also be used to grant temporary mod-like powers to a user
    • Not necessary for synchronization as the server has an internal timer
  • Channel state saves/loads on restart
  • Account management
    • Password change
    • Password reset (via email)
    • Profile avatar and text
  • Moderation
    • Mute users
    • Kick users
    • Ban users by name
    • Ban users by IP address (and by /24 range)
  • Administration
    • Log viewer
    • Global bans
    • Search registered channels and users
    • Currently loaded channels
    • Stats (usercount, channelcount, RAM usage)

Installing

Installation instructions are available here: https://github.com/calzoneman/sync/wiki/CyTube-3.0-Installation-Guide

Feedback

Please open a GitHub Issue.

License

Licensed under MIT. See LICENSE for the full license text.