Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

socket.io socket.set and socket.get - what is the callback argument for?

I just want to attach some variables to my sockets, but I don't understand the .get and .set methods. They both have a third argument for a callback. Can this be omitted? What is it for?! Does the callback itself intherit arguments?

My best guess is that it's there for when socket.io isn't using memory store but is saving this stuff somewhere else and needs an error checking callback.

socket.on('set nickname', function (name) {
    socket.set('nickname', name, function (arguments) {
      doSomethingMysterious();
    });

I'm using socket.io 0.9.x

The function is defined in socket.js

/**
 * Stores data for the client.
 *
 * @api public
 */

Socket.prototype.set = function (key, value, fn) {
  this.store.set(key, value, fn);
  return this;
};
like image 996
Karl Keefer Avatar asked Apr 28 '12 02:04

Karl Keefer


People also ask

Does Socket emit have callback?

Event CallbacksThe socketio. Server. emit() method has an optional callback argument that can be set to a callable. If this argument is given, the callable will be invoked after the client has processed the event, and any values returned by the client will be passed as arguments to this function.

How do you check if socket IO client is connected or not?

You can check the socket. connected property: var socket = io. connect(); console.

What is the difference between Socket.IO and socket IO client?

socket-io. client is the code for the client-side implementation of socket.io. That code may be used either by a browser client or by a server process that is initiating a socket.io connection to some other server (thus playing the client-side role in a socket.io connection).

Does Socket.IO reconnect automatically?

In the first case, the Socket will automatically try to reconnect, after a given delay.


1 Answers

The get and set functions on the socket object were removed in version 1.x. The proper way to store and retrieve values now is through properties on the socket object, like so:

socket.on('set nickname', function (name) {
  socket.nickname = name;
});

As seen on the example code from the official repo.

like image 176
caike Avatar answered Nov 15 '22 15:11

caike