B4i Library Socket.IO Client Library

Here is the Socket.IO Client library wrap for this Github Project.
Click here for the B4A wrapper

iSocketIOClient
Author:
@Biswajit
Version: 1.4
Dependency: iRandomAccessFile
  • iSocketIOClient
    SocketIOClient library wrapper for b4i.
    • Events:
      • Ack (data As String)
      • CustomUserEvents (data As List, ack As Object)
      • OnConnect (data As List)
      • OnConnecting (data As List)
      • OnDisconnect (data As List)
      • OnError (data As List)
      • OnReconnectAttempt (data As List)
      • OnReconnecting (data As List)
    • Functions:
      • AddListener (forEvent As String, callbackSub As String) As String
        Add custom event listener. It will return an UUID. Use that UUID to remove this particular listener.
        <b>Example:</b> <code>socket.AddListener("serverevent","appevent")</code>
      • Connect (host As String, namespace As String, params As Map, secure As Boolean, server_version As Int)
        Connect SocketIO to the server
        For default namespace pass null
        Pass server_version 2 if you use socket.io v2 on the server. For socket.io v3 or later send 3
        <b>Example:</b> <code>socket.connect("http://172.0.0.1:999/",null,null,false)</code>
        Other parameters will have default value as followings:
        <b>reconnection</b> = True
        <b>reconnectionAttempts</b> = Infinite
        <b>reconnectionDelay</b> = 1
        <b>reconnectionDelayMax</b> = 10
        <b>timeout</b> = 30
      • ConnectWithOptions (host As String, namespace As String, params As Map, secure As Boolean, reconnection As Boolean, reconnectionAttempts As Int, reconnectionDelay As Int, reconnectionDelayMax As Int, timeout As Int, server_version As Int)
        Connect SocketIO to the server with custom options
        For default namespace pass null
        Pass server_version 2 if you use socket.io v2 on the server. For socket.io v3 or later send 3
        <b>Example:</b> <code>socket.connect("http://172.0.0.1:999/",null,CreateMap("test":"data"),false, true, 5,1,10,30) </code>
      • DebugLog (enable As Boolean)
        Turn on debug log. Must be called before connecting. If you are already connected call disconnect then connect again.
      • Disconnect
        Disconnect SocketIO
        On successful disconnection it will raise 'OnDisconnect' event
      • EmitBinary (event As String, data As Object)
        Same as EmitString but used to send object. Usually used to forward an object to another device.
        <b>NOTE:</b> Internally it use the B4XSerializor to serialize the object.
        <b>Example:</b> <code>socket.EmitBinary("serverevent",anyObject)</code>
      • EmitString (event As String, data As Object)
        Sends a message to the server, requesting an ack.
        <b>NOTE:</b> It is upto the server send an ack back, just calling this method does not mean the server will acknowledge.
        <b>Example:</b> <code>socket.EmitString("serverevent","something")</code>
        <b>Getting Acknowledgment from server</b><code>
        Sub serverevent_Ack(data As String)
        Log(data)
        End Sub</code>
      • Initialize (EventName As String)
        Initializes the Socket.io object
      • IsInitialized As Boolean
        Tests whether this object was initialized.
      • RemoveAllListener (forEvent As String)
        Remove all event listeners for given eventname
        <b>Example:</b> <code>socket.RemoveAllListener("serverevent")</code>
      • RemoveListener (listenerUUID As String)
        Remove a particular event listener
        <b>Example:</b> <code>socket.RemoveListener("uuid_received_from_AddListener")</code>
      • SendAck (ack As Object, data As String)
        Call to acknowledge receiving an event.

Installation:
  1. Copy XML file to B4I additional library folder.
  2. Copy .framework, .h and .a files to Libs folder of the local build server
Example Attached.
For the server code you can check Socket.IO Github example or you can use this following chat server example (written in javascript) [attached]:

JavaScript:
const express = require("express");
const app = express();
const { createServer } = require("http");
const { Server } = require("socket.io");
var users = {};

// *** FOR SECURE CONNECTION *** //

// const fs = require('fs');
// var options = {
//   key: fs.readFileSync('./key.pem'),
//   cert: fs.readFileSync('./cert.pem'),
//   passphrase: "password of cert/key file"
// };

// const httpServer = createServer(options, app);

// *** FOR NON-SECURE CONNECTION *** //
const httpServer = createServer(app);

const io = new Server(httpServer,{allowEIO3: true});

io.on("connection", (socket) => {
    console.log("User Connected.");

    socket.on('user_msg', function(data,callback){
        io.emit('new_message', data);
        callback("Data Received");
    });

    socket.on('disconnect', function(data){
        console.log('User disconnected. Reason: ' + data);
    });

    socket.on('error',function(er){
        console.log(er);
    });
});

httpServer.listen(5555, function(){
  console.log('listening on *:5555');
});

To run this example server code:
  1. Download NodeJS.
  2. Install it.
  3. Download library zip file and extract.
  4. Run cmd inside server folder
  5. Run npm install
  6. It will take some time to complete.
  7. After that run node app.js
  8. It will show listening on *:5555
  9. Now create you app and connect.
  10. That's it!
Update v1.01:
  1. Added ConnectParams method for sending additional GET parameters.
Update v1.30:
  1. Completely rewritten from scratch (though the methods are almost the same)
  2. Support binary transfer.
    1. Any object you send from B4I will only be accessible from B4I directly.
    2. For B4A, use B4XSerializer in B4A to convert the received object buffer to object.
    3. You cannot access the object from the server.
  3. Add multiple listeners to a particular event
  4. Remove all listeners for a particular event or one by one
  5. Now you can send multiple parameters from the server and receive them as a list.
Update v1.40:
  1. Based on the latest working version.
  2. Connection methods' signatures have been changed. Check above.
  3. This version is compatible with Socket.io server v2, v3, v4.
  4. Now you have to pass the server version while connecting to the server.
    1. For v2.x.x pass 2
    2. For v3.x.x and later pass 3
  5. Socket.io server v1 is no longer supported. Those who want to use v1 download the older wrapper and frameworks.
  6. Consider this as the last update because Objective-C is no longer supported.
Download all the files from here

Download previous version from here
 

Attachments

  • socket.io v1.40 example.zip
    3.3 KB · Views: 29
Last edited:

Biswajit

Active Member
Licensed User
Longtime User
Hi,
The following error occurs when using the library:
error:
note: Build preparation complete
warning: Building targets in manual order is deprecated - check "Parallelize build for command-line builds" in the project editor, or set DISABLE_MANUAL_TARGET_ORDER_BUILD_WARNING in any of the targets in the current build to suppress this warning
/Users/admin/Desktop/B4iBuildServer/UploadedProjects/<user id>/B4iProject.xcodeproj: error: Building for iOS, but the linked and embedded framework 'Starscream.framework' was built for iOS + iOS Simulator. (in target 'B4iProject' from project 'B4iProject')
/Users/admin/Desktop/B4iBuildServer/UploadedProjects/<user id>/B4iProject.xcodeproj: error: Building for iOS, but the linked and embedded framework 'SocketIO.framework' was built for iOS + iOS Simulator. (in target 'B4iProject' from project 'B4iProject')

Error: ** BUILD FAILED **
Are you using the latest wrapper and frameworks?
 

Johan Hormaza

Well-Known Member
Licensed User
Longtime User
Is it possible to create the server with B4J?
To run this example server code:
  1. Download NodeJS.
  2. Install it.
  3. Download library zip file and extract.
  4. Run cmd inside server folder
  5. Run npm install
  6. It will take some time to complete.
  7. After that run node app.js
  8. It will show listening on *:999
  9. Now create you app and connect.
  10. That's it!
 

Biswajit

Active Member
Licensed User
Longtime User
Can you fix this error?
Sorry! I am a little busy this week. I will try to check the wrapper this weekend.

Though the issue you posted seems like related to the framework file. The framework has code for both ios and simulator. Maybe the new version of Xcode don't allow to use of that kind of framework.

Backup the current framework files and download the attached frameworks to check if the issue gets resolved or not.

Download
 

Biswajit

Active Member
Licensed User
Longtime User
Is it possible to create the server with B4J?
Maybe yes. But the official socket.io website doesn't have any Java SDK listed for Socket.IO server. I have to check which third-party socket.io server works with these wrappers and wrap that to use in B4J.

This process is quite time-consuming. If possible I will check this weekend.
 

Johan Hormaza

Well-Known Member
Licensed User
Longtime User
Maybe yes. But the official socket.io website doesn't have any Java SDK listed for Socket.IO server. I have to check which third-party socket.io server works with these wrappers and wrap that to use in B4J.

This process is quite time-consuming. If possible I will check this weekend.
Thanks my friend
 

José A.

Member
Licensed User
Maybe yes. But the official socket.io website doesn't have any Java SDK listed for Socket.IO server. I have to check which third-party socket.io server works with these wrappers and wrap that to use in B4J.

This process is quite time-consuming. If possible I will check this weekend.
Hi! Nice to meet you.
Did you finish the Simple audio call over internet with own TURN/relay server project?
Does it work?, I'm interested.
Thank you very much.
 

José A.

Member
Licensed User
si, si muchas gracias.
Pero yo estaba interesado en el primer proyecto.
Extremo a Extremo, android e ios.
Muchas gracias por todo.
 

José A.

Member
Licensed User
yes, yes thank you very much.
But I was interested in the first project.
End to End, android and ios.
Thank you so much for everything.
 

futurec

Member
Licensed User
Longtime User
Hi,
The following error occurs when using the library:
error:
note: Build preparation complete
warning: Building targets in manual order is deprecated - check "Parallelize build for command-line builds" in the project editor, or set DISABLE_MANUAL_TARGET_ORDER_BUILD_WARNING in any of the targets in the current build to suppress this warning
/Users/admin/Desktop/B4iBuildServer/UploadedProjects/<user id>/B4iProject.xcodeproj: error: Building for iOS, but the linked and embedded framework 'Starscream.framework' was built for iOS + iOS Simulator. (in target 'B4iProject' from project 'B4iProject')
/Users/admin/Desktop/B4iBuildServer/UploadedProjects/<user id>/B4iProject.xcodeproj: error: Building for iOS, but the linked and embedded framework 'SocketIO.framework' was built for iOS + iOS Simulator. (in target 'B4iProject' from project 'B4iProject')

Error: ** BUILD FAILED **
Hello
I also get this error
Please check, thank you
 

Biswajit

Active Member
Licensed User
Longtime User
When wrapping a library, support it.
This library has a problem, but you did not do anything at all.
If there is a need for a fee, tell me to deposit.
Sorry for the late reply. I was ill. Please consider posting your query directly to the forum that way other members can also help if they know the solution. Will try to find the solution.

Thanks.
 

Biswajit

Active Member
Licensed User
Longtime User
Hi,
Not completed?
I'm working on it and will post it when it's done. As this library was posted for all the members I have to check the android version also else the connection between both wrappers will not work when upgrading the ios version. This whole process takes time.

I am not a full-time B4X library developer. I do this in my free time. If you have a deadline you can dm me or post it on the job offer forum and I will prioritize the task.
 

Biswajit

Active Member
Licensed User
Longtime User
Update v1.40:
  1. Based on the latest working version.
  2. Connection methods' signatures have been changed. Check above.
  3. This version is compatible with Socket.io server v2, v3, v4.
  4. Now you have to pass the server version while connecting to the server.
    1. For v2.x.x pass 2
    2. For v3.x.x and later pass 3
  5. Socket.io server v1 is no longer supported. Those who want to use v1 download the older wrapper and frameworks.
  6. Consider this as the last update because Objective-C is no longer supported.
 

Biswajit

Active Member
Licensed User
Longtime User
Hi
When I use "EmitString" it gives the following error:
Error:
-[__NSCFNumber bytes]: unrecognized selector sent to instance 0x92d379ca88f8548a
When you post an issue you have to post the relevant code also just by seeing this error log no one can guess what is the error.
 
Last edited:

Biswajit

Active Member
Licensed User
Longtime User
Hanta -[B4IArray setBytesData:] + 92
Hanta -[B4INativeObject NSDataToArray:] + 116
Hanta __32-[iSocketIOClient AddListener::]_block_invoke + 356
As per these three lines, the error is occurring from the B4XSerializor that I used internally to convert list, map, array object to byte. Also, the issue is not coming from the EmitString. It's coming from the AddListener function.

Can you post the block_invoke sub code and what type of data you are sending from the server to this listener? If you don't want to post publicly you can dm me.
 

Biswajit

Active Member
Licensed User
Longtime User
Private Sub socket_joinroom(txt As String)
the method signature is wrong. The parameter should be a list not string. check the first post or the example project
 

Similar Threads

Top