Skip to content
ideawu edited this page Apr 15, 2014 · 42 revisions

iComet APIs

Public port

The public(or front) port is the port that clients can connect to and receive messages from the comet server. The default port number is 8100.

Subscribe to a channel

Request:

Long-polling

http://127.0.0.1:8100/poll?cname=$channel&seq=$next_seq&token=$token

Forever iframe

http://127.0.0.1:8100/iframe?cname=$channel&seq=$next_seq&token=$token

Streaming(HTTP endless chunk)

http://127.0.0.1:8100/stream?cname=$channel&seq=$next_seq&token=$token

Parameters:

  • cname: The name of the channel this client will subscribe to.
  • token: Token is returned by /sign.
  • seq: The sequence number of the next data message that will be sent by iComet server. iComet client must remember every message's sequence number, plus it with 1, and used for next polling or reconnect streaming.

Response:

If the HTTP response tatus code is not 200, it is likely that the iComet server is down.

Long-polling

icomet_cb([{type: "data", cname: "a", seq: "1", content: "a"}]);
icomet_cb({type: "data", cname: "a", seq: "1", content: "a"});

When there are buffered messages attached with the channel, the response is as the first one, the parameter of the function call is an array of message objects.

When a new message arrives, the response is as the second one, the parameter of the function call is the message object.

Since the response is received, the request is finished, so the client must send another request.

Forever iframe

<script>parent.icomet_cb({type: "data", cname: "a", seq: "0", content: "a"});</script>

Each message(old and new) is responsed as a HTTP chunk, the chunk is a snipet of JavaScript code, the request is not finished, so client do not need to send another request.

Streaming(HTTP endless chunk)

{type: "data", cname: "a", seq: "1", content: "a"}

Each message(old and new) is responsed as a HTTP chunk, the request is not finished, so client do not need to send another request.

Parameters:

  • type: The type of this message
    • data: A normal message.
    • noop: An empty message.
    • 429: Error message, too many channels/subscribers.
    • 401: Error message, token error.

Administration port

The administration(or admin) port is the port that internal services will connect to, to create a channel, publish a message, close a channel, etc. Clients are forbidden to connect to this port. The default port number is 8000.

/sign Create channel

Request:

http://127.0.0.1:8000/sign?cname=$channel[&expires=60]

The created channel will be waiting for 60 seconds to expire before any subscriber arrives.

Response:

{type: "sign", cname: "a", seq: 0, token: "36289dcb55bc35aa6893f7557b7fc28c", expires: 30, sub_timeout: 10}

/pub Publish/Push message

Request:

http://127.0.0.1:8000/pub?cname=$channel&content=$content&encoded=1

Response:

{type: "ok"}

$content must be JSON encoded string, without the leading and trailing quote pair, if encoded=1, otherwise, the icomet server will encode that string to ensure the JSON string push to subscribers is valid.

Clone this wiki locally