The Bug:
* The dark video detector on chat sometimes triggered false positives,
and it would read a solid black screenshot from the user's camera.
* My personal repro steps would be: if I plug my USB webcam in after
Firefox has already opened, the dark video detector would misfire and
get a black image every time. But if I restart Firefox after the
webcam is plugged in, it would work correctly and read screenshots off
the camera fine.
* A couple other users ran into the false positive too, where rebooting
their browser didn't work; it seemed either some webcam models or some
security setting on their device may have been related.
Through Some Experimenting:
* I found a demo page online which screenshots your camera into a Canvas
the exact same way I was doing, and it worked during the conditions
where BareRTC would have gotten a solid black screenshot.
* Previously, BareRTC was creating the Canvas dynamically by calling
document.createElement("canvas") and the Canvas wasn't added to the
web page DOM.
* So I added a <canvas id="darkVideoDetector"> to the DOM and used that
instead of creating a dynamic one.
* If the Canvas on the page were "visible" to the user, it would
successfully screenshot my webcam into it and read it back out. But if
the Canvas were "invisible", it would return a solid black image the
same as the dynamically created Canvas would.
* By "invisible" I mean: if the Canvas or its container had any CSS on
it such as display:none, visibility:hidden, opacity:0, or a
width/height of 0px, then the Canvas would not screenshot the webcam
and get a black image back.
* Note: even a low opacity setting like 0.1 would count the Canvas as
being "visible" and it would work correctly.
The Fix:
* A <canvas> tag is added to the page and is wrapped in a <div> which is
1x1 pixel in size and anchored to the bottom-right of the page,
thereby making the canvas "visible" and able to screenshot the webcam.
Some users had reported the dark video detector errors out on their
camera, reading a solid black image and average color of 0 despite their
camera actually being bright and colorful.
This case seems rare, but the nodvd moderation rule can lift the feature
for specific affected users while keeping it in place for everyone else.
Update the Ban button shown to admins in the Profile Modal:
* Now displays a modal for the admin to enter a reason and select the
duration (1-96 hours).
* Along with the ban, the reason is posted to your main website as an
admin report so you can log which chat admin banned which user and the
reason given.
* Set 640x480 as the ideal constraint for most users.
* But if their webcam physically can't output that resolution, allow
them to choose the nearest up to 1280x720.
* When an admin has marked your camera 'red' for you, the Explicit button at the
top of the page now will require *two* clicks if the user wants to set their
camera back to blue:
On first click, they will get a red ChatClient message explaining that their
cam was most-recently marked red due to a server action (such as a moderator
flagging their cam for them). If they really mean to mark their camera blue,
they are instructed to click it a second time to confirm.
* This behavior only occurs when the most recent NSFW setting was dictated by
the server (e.g. a 'me' event disagreed with the page's local NSFW setting).
The flag is cleared any time the user themself toggles the flag, or when the
first ChatClient warning after a server event is shown.
* The explicit camera settings in the broadcast modal have been rearranged and
reworded.
* Add an 'advanced' webcam feature to automatically broadcast in the future on
page load. The option is only available in the Chat Settings 'Camera' tab
after you are already broadcasting (or rather: when a list of video devices
have become available to the page, indicating the user has possibly granted
permission already).
Apparently some iPad browsers were having their local webcam freeze
after a window.confirm prompt was shown. This replaces all uses of
window.confirm/window.alert with an in-app modal.
When the Safari browser puts a webcam video full-screen and then
returns, the z-index of the video was higher than the buttons and
controls normally overlaid on top of it.
Add a z-index:1 to the video controls to keep them on top after
returning from full screen. Similar: for popped-out draggable videos,
adding a z-index:1 allows the video to correctly sit on top of docked
videos without the docked video controls (zi:1) rendering above the
popped-out video when you overlap them.
Note: the z-index:1 is applied to popped-out and video controls, any
other combination (e.g. 1 for popped-out and 2 for controls) caused
controls of docked videos to render on top of popped-out ones when they
overlapped.
* Add local detection for users who are broadcasting dark (e.g. mostly
or completely black) video feeds from their local device.
* Every 5 seconds while the webcam is active, the average RGB color is
sampled. If the average color value remains below 60 (out of 255) for
two consecutive samples, the camera is stopped automatically.
Add moderation rules:
* You can apply rules in the settings.toml to enforce moderator restrictions on
certain users, e.g. to force their camera to always be NSFW or bar them from
sharing their webcam at all anymore.
Chat UI improvements around users blocking admin accounts:
* When a main website block is in place, the DMs button in the Who List shows
as greyed out with a cross through, as if that user had closed their DMs.
* Admin users are always able to watch the camera of people who have blocked
them. The broadcaster is not notified about the watch.
New operator commands:
* /cut username: to tell a user to turn off their webcam.
* /unmute-all: to lift all mutes on your side, e.g. so your moderator chatbot
can still see public messages from users who have blocked it.
* /help-advanced: moved the more dangerous admin command documentation here.
Miscellaneous fixes:
* The admin commands now tolerate an @ prefix in front of usernames.
* The /nsfw command won't fire unless the user's camera is actually active and
not marked as explicit.
* WebRTC functionality is now 100% working as intended for Safari and
iPad browsers!
* The legacy WebRTC API had properties like offerToReceiveVideo
available on createOffer(), to set up a receive-only channel, but the
modern WebRTC API had removed these and Safari only supports the
modern API.
* The modern solution for the same feature is to add a recvonly
transceiver to the connection in place of offering a local video/audio
stream to share.