Skip to content

All clients for mpp (client and server side) with typescript

Notifications You must be signed in to change notification settings

multiplayerpiano/mpp-clients

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 

Repository files navigation

API

Install

yarn add mpp-clients

Usage

import {BrowserClient} from 'mpp-clients/browserClient/BrowserClient'
// For server
// import {ServerClient} from 'mpp-clients/serverClient/ServerClient'
import {Action} from 'mpp-clients/actions'

const Client = BrowserClient; // or ServerClient

const start = async () => {
  const client = new Client(); // by default `{url: 'https://multiplayerpiano.com'}`
  
  // add listener before you connect to don't lose any actions.
  client.on(action => {
    if(action.type === Action.hi) {
      // do something
      console.log(action.payload)
    }
  })

  // Will send `client.send({type: 'hi'})`. @todo: we should wait for a server ack so we are sure that are connected.
  // Will throw an error if can't connect, so you need a try/catch
  await client.connect();

  // This will send a `request` type of action. Is not guaranteed that your action will be accepted by the server.
  // After that the server will emit an action back to client if has been successful or failed.
  client.send({type: 'note', payload: {/* Note arguments */}});

  await client.disconnect();
}

start();

Typescript Types

Import all Action types available in mpp.

import {Action} from 'mpp-clients/actions'

@todo: maybe mpp-clients/actions should be in another project so can be shared on server side.

Actions

All communication is done via actions to keep it simple and serializable.

App Actions

Actions created from the server and dispatched to all clients.

Client Actions

Actions created by clients/players. Those will be sent to the server, validated and only after that dispatched to all other clients.

Flow:

  • Request play note
  • Server validates you can play that note
  • Server replies to you with note play accepted (or rejected)
  • Server shares the note with all other clients

About

All clients for mpp (client and server side) with typescript

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published