Ok I think I am now saving endpoint ID's as such:

*On the server side:*



*var idCounter = 0;*























*function nextUniqueId() {        idCounter++;        return 
idCounter.toString();}var TotalViewers = 0;var viewersID = [ 
];wss.on('connection', function(ws) { var sessionId = nextUniqueId(); /* 
sessionId is a simple counter for # of viewers */        
console.log('Connection received with sessionId ' + sessionId);        
TotalViewers = TotalViewers + sessionId; /* Keep a running total of viewers 
and new viewers (sessionId's) */ var ids = 
ws.upgradeReq.headers['sec-websocket-key']; /* ids is the unique endpoint 
identifier? */        viewersID[sessionId] = ids;        console.log('New 
Connection viewerid : : ', viewersID[sessionId]);Now, how do I update each 
webpage (ids) with the value of TotalViewers?  I'm pretty sure I understand 
looping through for (x = 1 x<=sessionId, sessionId--)  
viewersID[sessionId]=TotalViewers;but I can't wrap my head around how this 
actually gets to the webpage? I think my code above is correct but maybe 
not.I appreciate comments...Ray*




On Monday, February 22, 2016 at 12:01:13 PM UTC-5, Ray Jender wrote:
>
> I am definitely using a particular library, ws.
> Is the sockets.push(ws) a valid command for that?  I could not find it 
> anywhere?
>
> Thanks,
>
> Ray
>
> On Sunday, February 21, 2016 at 9:56:05 PM UTC-5, Christopher Mina wrote:
>
>> Hi Ray. 
>>
>> You'll want to keep a reference to each web socket created (in an array 
>> or object hash) and a property on your server or in a database to track the 
>> number of active sessions. When a new connection is made (or closed), you 
>> will increment / decrement the count and then send a message event through 
>> each socket to the client. The client will be listening for that event (eg 
>> "count_changed") and when the event comes through, it will read the new 
>> count off the data payload of the event and render it to the screen. 
>>
>> I'm not sure if I'm answering your question or not. Maybe you are asking 
>> specifically about the particular library you're using? It seems to me, the 
>> confusion may just be in how you maintain a reference to each open web 
>> socket. 
>>
>> For instance :
>>
>> var sockets = [];
>> *wss.on('connection', function(ws) {*
>>
>> *    sockets.push(ws);*}
>>
>> You can now reference any socket created via this array. You'll want to 
>> ensure you are removing disconnected sockets as well, by listening for a 
>> disconnect event. 
>>
>> Hopefully this helps. 
>> Chris 
>>
>>
>> On Sunday, February 21, 2016, Ray [email protected]> wrote:
>>
>>> Thanks for the reply Chris.
>>>
>>> One of the confusions I am having is trying to impliment something 
>>> written for socket.io  to use in ws.
>>>
>>> But that said, I do have code to get the authkey, but I am confused how 
>>> the authkey can be used to access the webpage?
>>>
>>> So for code, I have:
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>> *function nextUniqueId() {        idCounter++;        return 
>>> idCounter.toString();}wss.on('connection', function(ws) {        var 
>>> sessionId = nextUniqueId();        console.log('Connection received with 
>>> sessionId ' + sessionId);        var id = 
>>> ws.upgradeReq.headers['sec-websocket-key'];        console.log('New 
>>> Connection id : : ', id);*So sessionid just counts the number of users, 
>>> which is what I want to display on all user pages.
>>>
>>> Right now, each user webpage is only showing what the total user count 
>>> is when the user created the ws.
>>> (1,2,3,4, etc).  So the first user is showing 1, the second user is 
>>> showing 2, and so on,
>>>
>>> So I am confused on how the var id above can be used to send data to a 
>>> particular webpage (websocket)?
>>>
>>>
>>> Thanks,
>>>
>>> Ray
>>>
>>>
>>>
>>> On Saturday, February 20, 2016 at 11:48:55 PM UTC-5, Christopher Mina 
>>> wrote:
>>>>
>>>> Sorry about that half finished post, my last post was sent 
>>>> prematurely...
>>>>
>>>> What I was getting at is that I now have access to the authkey during 
>>>> the setup phase.  I can use this auth key to query the database for 
>>>> information about that user and store it.  Now I have a way to directly 
>>>> associated the incoming websocket with a specific user.  
>>>>
>>>> I'll now store the actual websocket instances in one or more hash maps, 
>>>> and when I need to, for instance, send a single user some information, i 
>>>> can query that websocket via the socketUserId hash map.  Or if I want to 
>>>> send everyone a message, I'll loop through a list where I keep a reference 
>>>> to all sockets, and send each one the message individually.   This is just 
>>>> one way of doing it.  There are other more appropriate pub/sub mechanisms 
>>>> as well you could investigate. 
>>>>
>>>> Hopefully that helps a little bit. 
>>>> -Chris
>>>>
>>>>
>>>> On Saturday, February 20, 2016 at 7:26:54 PM UTC-7, Ray Jender wrote:
>>>>>
>>>>>
>>>>> Please bear with me as I am new to websockets.
>>>>>
>>>>> So, my problem is keeping track of websocket instances.
>>>>> I am trying to modify some existing open source javascript code.
>>>>>
>>>>> I have server.js, index.js and index.html files. As with any website,
>>>>> it could have many users browsing the page. There is only a single
>>>>> webpage.
>>>>>
>>>>> The basic operation is: index.html --> index.js --> server.js --> 
>>>>> index.js
>>>>>
>>>>> What I am having a hard time wrapping my head around is associating the
>>>>> websocket with the browser.   What I want to do  is be able to update 
>>>>> each webpage with the number of users.  I have googled tons of sites 
>>>>> but
>>>>> I am still very confused on how this should work.
>>>>>
>>>>> I've seen a thing like ws.broadcast, but  I am having a hard time 
>>>>> trying to
>>>>> implement that.  It seems that the way the opensource code I am using 
>>>>> initializes
>>>>> websockets way different than the examples I am seeing.
>>>>>
>>>>> I am using node v0.10.42, npm 1.4.29, express 4.12.4, minimist 1.1.1, 
>>>>> ws 0.7.2, bower 1.4.1
>>>>>
>>>>> I need a tutor to help me through this!  Care to volunteer?   I would 
>>>>> be so appreciative!!!
>>>>>
>>>>> Thanks,
>>>>>
>>>>> Ray
>>>>>
>>>>>
>>>>> -- 
>>> Job board: http://jobs.nodejs.org/
>>> New group rules: 
>>> https://gist.github.com/othiym23/9886289#file-moderation-policy-md
>>> Old group rules: 
>>> https://github.com/joyent/node/wiki/Mailing-List-Posting-Guidelines
>>> --- 
>>> You received this message because you are subscribed to a topic in the 
>>> Google Groups "nodejs" group.
>>> To unsubscribe from this topic, visit 
>>> https://groups.google.com/d/topic/nodejs/DVNUsoEhoRM/unsubscribe.
>>> To unsubscribe from this group and all its topics, send an email to 
>>> [email protected].
>>> To post to this group, send email to [email protected].
>>> To view this discussion on the web visit 
>>> https://groups.google.com/d/msgid/nodejs/0b7f961d-35a9-48e4-9dff-d79c9322f9bd%40googlegroups.com
>>>  
>>> <https://groups.google.com/d/msgid/nodejs/0b7f961d-35a9-48e4-9dff-d79c9322f9bd%40googlegroups.com?utm_medium=email&utm_source=footer>
>>> .
>>> For more options, visit https://groups.google.com/d/optout.
>>>
>>
>>
>> -- 
>> Christopher Mina
>>
>> Live Healthy. Work Hard. Be Kind. Gain Success.
>>
>>

-- 
Job board: http://jobs.nodejs.org/
New group rules: 
https://gist.github.com/othiym23/9886289#file-moderation-policy-md
Old group rules: 
https://github.com/joyent/node/wiki/Mailing-List-Posting-Guidelines
--- 
You received this message because you are subscribed to the Google Groups 
"nodejs" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/nodejs/66a1b512-e01b-4973-a4f1-86688362c676%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to