Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MIDI-CI messages without sysex permission #240

Open
chrisguttandin opened this issue Dec 23, 2022 · 3 comments
Open

MIDI-CI messages without sysex permission #240

chrisguttandin opened this issue Dec 23, 2022 · 3 comments
Labels
category: enhancement https://www.w3.org/policies/process/#class-3 MIDI2 https://midi.org/midi-2-0 Needs Discussion The issue needs more discussion before it can be fixed. Priority: Eventually https://speced.github.io/spec-maintenance/about/
Milestone

Comments

@chrisguttandin
Copy link

MIDI-CI messages are backwards compatible with MIDI v1. Technically they are just System Exclusive messages. But they follow a strict protocol just like any other regular MIDI message.

I think it's a bit overkill to ask the user for the permission to send sysex messages when only sending MIDI-CI messages. Therefore I would propose to allow MIDI-CI messages even though the user only gave permission for { name: 'midi' } and didn't explicitly opt-in with { name: 'midi', sysex: true }.

@bradisbell
Copy link

Dropping the extra permission for SysEx entirely solves this problem among others.

No real semantic meaning can definitively be assumed about sysex-or-not If there's a security concern, it should be read/read-write instead of midi/midi+sysex.

@cwilso
Copy link
Contributor

cwilso commented Dec 24, 2022

It would be a significant task to do a privacy and security review of MIDI-CI (https://developer.apple.com/documentation/coremidi/midi_capability_inquiry), and it IS adding additional privacy surface area (you can tell a lot more about what devices are connected to a MIDI port). Before looking at Apple's MIDI-CI, I would also enable MIDI machine controls without sysex (https://www.midi.org/specifications/midi1-specifications/rp-013-v1-0-midi-machine-control-specification-96-1-4) - but I think most systems are going to require significant permissions to get MIDI access anyway (Firefox does, and Chromium is intending to add permissions for basic MIDI.). I'm not sure this is worthwhile.

@chrisguttandin
Copy link
Author

@bradisbell I'm not sure if dropping the extra sysex permission flag would be realistic anytime soon. Looks like things are going the other direction. But if they do and users have to click several times even before they can use Web MIDI without sysex it might make not much difference anymore to ask for it, too.

@cwilso Oh yes, you're totally right. I reveals a lot more infos and might be a privacy issue. I totally forgot about that aspect.

@hoch hoch added the MIDI2 https://midi.org/midi-2-0 label Mar 23, 2023
@mjwilson-google mjwilson-google added the category: enhancement https://www.w3.org/policies/process/#class-3 label Sep 13, 2023
@mjwilson-google mjwilson-google added this to the future-work milestone Sep 14, 2023
@mjwilson-google mjwilson-google added Needs Discussion The issue needs more discussion before it can be fixed. Priority: Eventually https://speced.github.io/spec-maintenance/about/ labels Nov 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
category: enhancement https://www.w3.org/policies/process/#class-3 MIDI2 https://midi.org/midi-2-0 Needs Discussion The issue needs more discussion before it can be fixed. Priority: Eventually https://speced.github.io/spec-maintenance/about/
Projects
None yet
Development

No branches or pull requests

5 participants