
Research
SANDWORM_MODE: Shai-Hulud-Style npm Worm Hijacks CI Workflows and Poisons AI Toolchains
An emerging npm supply chain attack that infects repos, steals CI secrets, and targets developer AI toolchains for further compromise.
aframe-proxy-controls
Advanced tools
A-Frame component to proxy keyboard/gamepad controls between devices over WebRTC.
proxy-controls ComponentA-Frame component to proxy keyboard/gamepad controls between devices over WebRTC.
With a mobile device / Google Cardboard for WebVR, designing the UI around a single button is an obstacle. This component provides an experimental way to proxy user input events (keyboard, perhaps Leap Motion later) from a keyboard-connected device to the mobile viewer.
For performance, WebRTC DataStreams are used to minimize latency between the devices. Browser support for this standard is limited - notably, Safari (including all iPhone browsers) does not support it. I will consider adding fallback support via WebSockets in the future, if the latency is bearable.
Add the proxy-controls component to the scene, and use one of the input controller components on the object(s) you want to control. For example:
<a-scene proxy-controls>
<a-entity id="player" gamepad-controls="controller: 2"></a-entity>
</a-scene>
The gamepad-controls component is available separately, here.
Options are assigned with A-Frame's entity/component/property pattern:
<a-scene camera proxy-controls="enabled: true;
debug: true;
pairCode: 'my-secret-code';
enableOverlay: false;">
<!-- scene content -->
</a-scene>
| Property | Default | Description |
|---|---|---|
| enabled | true | Enables/disables event updates from the host. |
| debug | false | Enables/disables logging in the console. |
| proxyUrl | https://proxy-controls.donmccurdy.com | URL of the remote proxy server / signaling server. |
| pairCode | <random> | Pair code that should be used to match with the remote host. If not provided, a random pair code is assigned. |
| enableOverlay | true | Enables/disables the overlay UI showing the pair code. |
| enableOverlayStyles | true | Enables/disables the CSS used to style the pair code overlay. |
When the pair code is available, a proxycontrols.paircode event is fired. If you want to hide the default overlay, use this to show the pair code to the user as needed:
scene.addEventListener('proxycontrols.paircode', function (e) {
console.log(e.detail.pairCode);
});
FAQs
A-Frame component to proxy keyboard/gamepad controls between devices over WebRTC.
The npm package aframe-proxy-controls receives a total of 14 weekly downloads. As such, aframe-proxy-controls popularity was classified as not popular.
We found that aframe-proxy-controls demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Research
An emerging npm supply chain attack that infects repos, steals CI secrets, and targets developer AI toolchains for further compromise.

Company News
Socket is proud to join the OpenJS Foundation as a Silver Member, deepening our commitment to the long-term health and security of the JavaScript ecosystem.

Security News
npm now links to Socket's security analysis on every package page. Here's what you'll find when you click through.