Skip to content

this is a type safe library to communicate to the phoenix channels in elixir.

License

Notifications You must be signed in to change notification settings

saisumith770/phx-socket

Repository files navigation

phx-socket

Introduction

This is a websocket library for typescript built to interact with the phoenix websocket server. This is because phoenix has an abstraction around the general http socket layer. This library will simplify the procedure.

What I'm trying to solve

The regular features like connecting the socket, sending messages ,checking state, timers etc are features that you'll already find in libraries like PhoenixJs. In fact there tons of libraries out there that allow you to connect to websockets. Our goal comes from the sophistication that phoenix framework has developed, which is to subscribe to channels. But that isn't the problem, the problem is when you set event listeners, here the complications start as there may be multiple channels that may have the same events. Even what if you wanted to create a separate listener for each event with different callbacks as different parts of your code might depend on that event differently.

Our Concept

The way I want to solve this issue is setup events and then allow channels and callbacks to subscribe to them. So that when an event takes place all the callbacks to that event fire and when an event is turned off all callbacks and channels can unsubscribe. The best part of this model is that everything is broken into small units so that if you want to unsubscribe only one callback then you can do so without affecting the others.

Progress

I've built the rough implementation but have to test it and check whether it works?

Installation

  npm i phx-socket

Objects

Socket

This is a class that would initiate the connection. Although in most of your programs this is the only class that you will be importing.

Methods

Socket.topics

This method returns all the topics that you have subscribed to.

Socket.state

This method returns the state of the websocket.

Socket.subscribe(topic:string)

This method allows you to subscribe to a certain topic with ease.

Socket.unsubscribe(topic:string)

This method allows you to unsubscribe from a certain topic with ease.

Socket.on(event: SocketEvent | string, callback: (socket: WebSocket, event: MessageEvent | CloseEvent | Event) => void)

This method sets up a listener for a certain event and gives you the flexibility to customize what the function should do.

Socket.send(message: MessageType)

This method sends a message to the websocket but you would have to specify the topic as well.

Socket.close()

This method will close the websocket session.

Usage

    const inst = new Socket("ws://localhost:4000/ws/websocket")
    inst.on("phx_reply",(_,__) => {
        console.log("successfully connected to the websocket")
    })
    inst.send({
        topic:"room:lobby",
        event:"phx_join",
        payload:{}
    })

Channel

This class is a higher abstraction around the Socket class. It will allow you to write and read messages directly from the channel rather than the global socket class while also making the syntax easier.

Methods

Channel.topic

This method returns the name of the topic that the channel is subscribed to.

Channel.send(message: Omit<MessageType,"topic">)

This method does the exact same thing as Socket.send but you do not have to mention the topic.

Channel.on(event: string, callback: (socket: WebSocket, event: MessageEvent) => void)

This method does the exact same thing as the Socket.on but also adds an additional check whether it is on the right channel. This is important to understand as in the case of the global socket if you add an event listener then irrespective of which channel the event is coming from the callback will be executed. In this case only if the event comes from the given channel then the callback will be executed.

Usage

    const inst = new Socket("ws://localhost:4000/ws/websocket")
    const room = inst.subscribe("room:lobby")
    room?.on("phx_reply",(_,event) => {
      console.log(event)
    })
    room?.on("shout",(_,event) => {
      console.log("shout")
    })
    room?.send({
      event:"shout",
      payload:{
        greet:"hey there"
      }
    })

EventCollection

This is an internal class and is not to be used outside the library. Although you wouldn't find much use from it as it only tracks the events and keeps them in check. Which is required for the functioning of the library but may not be useful for writing your software.

Methods

EventCollection.eventsArray

This method would return the events stored in the instance.

EventCollection.addEventToListen(event: SocketEvent | string, callback: (socket: WebSocket, event: MessageEvent | CloseEvent | Event) => void)

This method would add an event to the instance and this would help in monitoring all the available events.

Usage

    const _events:EventCollection = new EventCollection()
    _events.addEventToListen("someEvent",(_,__) => null)
    console.log(_events.eventsArray)

About

this is a type safe library to communicate to the phoenix channels in elixir.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published