-
Notifications
You must be signed in to change notification settings - Fork 617
Endpoints
When connecting to BIMserver from another machine/process, you usually use the JSON, ProtocolBuffers or SOAP calls. Those are RPC-like calls that do or do not return something in a synchronous way.
Sometimes you want the communication to be issued the other way around. You want BIMserver to initiate. For this to work, the remote side has to tell the BIMserver it is interested.
The remote side has to register an EndPoint. For now the only type of EndPoint available is a WebSocket. You have to setup a WebSocket to http://[YOUR HOST]:[OPTIONAL PORT]/[OPTIONAL CONTEXT]/stream
. BIMserver will send a JSON message:
{
welcome: 12345
}
The number in this message is the current time as UTC milliseconds from the epoch.
You have to send your token
next, this is the same token you use for normal calls to BIMserver
{
token: ABCDE...
}
Then BIMserver will send you an endPointID
, this EndPoint will be matched with the User linked to the token you sent earlier.
{
endpointid: 12345...
}
Now you can use this endPointID
when registering for certain events, such as progress on some action:
NotificationRegistryInterface.registerProgressHandler(topicId, endPointId);
In the previuos example the topicId
is being returned by for example the ServiceInterface.checkin
method.
Are you using the BIMserver JavaScript API? Then you can register events a bit easier. The API will setup the WebSocket for you.
bimServerApi.registerProgressHandler(topicId, handler, callback);
In this example, handler
should be a function reference to the function that should be executed when the progress changes, the callback
will be called after the handler
is successfully registered.
To make sure no memory and processing power is wasted, please remember to unregister any unused handlers.
Get Started
- Quick Guide
- Requirements Version 1.2
- Requirements Version 1.3
- Requirements Version 1.4
- Requirements Version 1.4 > 2015-09-12
- Requirements Version 1.5
- Download
- JAR Starter
- Setup
Deployment
- Ubuntu installation
- Windows installation
- Security
- Memory Usage
- More memory
- Performance statistics
- Large databases
Developers
- Service Interfaces
- Common functions
- Data Model
- Low Level Calls
- Endpoints
Clients
BIMServer Developers
- Plugins in 1.5
- Plugin Development
- Eclipse
- Eclipse Modeling Framework
- Embedding
- Terminology
- Database/Versioning
- IFC STEP Encoding
- Communication
- Global changes in 1.5
- Writing a service
- Services/Notifications
- BIMserver 1.5 Developers
- Extended data
- Extended data schema
- Object IDM
New developments
- New remote service interface
- Plugins new
- Deprecated
- New query language
- Visual query language
- Reorganizing BIMserver JavaScript API
General