Skip to content

Latest commit

 

History

History
167 lines (136 loc) · 3.83 KB

API.md

File metadata and controls

167 lines (136 loc) · 3.83 KB

API from Bach to Mozart

  • joinGroup: joinGroup is the first step of UI flow. Bach sends this event with the group code. If a group with the code is already existed, server returns the group information. If a group is not created, server creates the group and sends the empty group information back.
  {
    "event": "joinGroup",
    "code": "code"
  }
  • requestRole: requestRole is the event that UI sends to server to state the role of UI. The role can be conductor or musician. A group only has a single conductor. If the group already have the conductor, server should return musician in role field.
  {
    "event": "requestRole",
    "role": "conductor"
  }
  • setSpeed: this API is used for telling server the current speed made by conductor.
  {
    "event": "setSpeed",
    "speed": 0.9 // this may be changed if we can support bpm.
  }
  • setSong: this API is used for telling server which song we want to play.
  {
    "event": "setSong",
    "song": "bumblebee"
  }
  • setVolume: this API is used for telling server the volume of specific channel.
  {
    "event": "setVolume",
    "channel": 1,
    "volume": 0.7
  }
  • start: this API is used for telling server to freeze the group and distribute instruments to all musicians.
  {
    "event": "start"
  }
  • musicianReady: this API is used for telling conductor this musician is ready for playing, who already loaded all resources.
  {
    "event": "musicianReady"
  }

API from Mozart to Bach

  • joinGroup: the result of the joinGroup request. It ships with group information, for example:
  {
    "event": "joinGroup",
    "group": {
      "hasConductor": false,
      "musicianCount": 1,
      "readyCount": 0
    }
  }
  • requestRole: the result of the requestRole request. The real role is returned with role field.
  {
    "event": "requestRole",
    "role": "musician",
    "group": {
      "song": "bumblebee",
      "hasConductor": false,
      "musicianCount": 1,
      "readyCount": 0
    }
  }
  • trackInfo: trackInfo is the event when the conductor click start button. All group members receives this event, but conductor will receive the empty result in channels. An example looks like:
  {
    "event": "trackInfo",
    "channels": [ 0, 1 ],
    "instruments": [ "acoustic_grand_piano", "violin" ],
    "group": {
      "song": "bumblebee",
      "hasConductor": true,
      "musicianCount": 1,
      "readyCount": 0,
      "volumes": [0.5, 0.5, 05, 0.5]
    }
  }
  • groupChanged: groupChanged is the event when a musician or conductor is joined to this group or a musician is left from this group. An example looks like:
  {
    "event": "groupChanged",
    "group": {
      "song": "bumblebee",
      "hasConductor": true,
      "musicianCount": 2,
      "readyCount": 1,
      "volumes": [0.5, 0.5, 0.7, 0.2]
    }
  }
  • groupClosed: groupClosed is the event when the conductor is left from this group. The data of group is deleted from server. All UI should turn note off while receiving this event. An example looks like:
  {
    "event": "groupClosed"
  }
  • noteOn: noteOn is the event to tell this UI to play a note. An example looks like:
  {
    "event": "noteOn",
    "notes": [{
      "note": 94,
      "velocity": 1
    }]
  }
  • noteOff: noteOff is the event to tell this UI to mute a note. An example looks like:
  {
    "event": "noteOff",
    "notes": [{
      "note": 94
    }]
  }
  • songInfo: songInfo is the event to tell conductor the song information he/she chose.
  {
    "event": "songInfo",
    "song": "bumblebee",
    "tracks": [['acoustic_grand_piano'], ['acoustic_grand_piano']]
    }
  }