Files
Tobias Oberstein 0af895bff0 Newapi asyncio component (#872)
* start of asyncio side of component API

* copy-pasta the authentication stuff for now

* add 'trust_root' to TLS config, fix generic component errors

* change MyAuthorizer to match component examples

* new certificate; expired

* move auth code to central place, refactor general new-Session code

* fixes to asyncio, unix, some flake8

* refactor authentication API

add_authenticator now takes an instance of IAuthenticator
that we construct with a factory function

* unused imports

* no qa on invalid syntax for py 2
2017-07-19 14:15:26 +02:00
..
2017-06-10 12:45:40 +02:00
2017-03-31 11:14:05 -06:00
2016-07-17 16:41:59 +02:00
2017-06-10 12:45:40 +02:00
2017-07-19 14:15:26 +02:00
2016-07-15 17:19:00 +02:00

WAMP Programming Examples

There are several very-similar examples that each follow a similar form and demonstrate several different ways of using WAMP under Autobahn. Each of these examples usually includes:

  • backend.py: the logical "backend", in Python (registers procedures, publishes events)
  • frontend.py: the logical "frontend", in Python (calls endpoints, receives events)
  • frontend.js: similar version in JavaScript
  • backend.js: similar version in JavaScript
  • *.html: boilerplate to hold the .js

Note that any WAMP component can "do" all the roles (so a "backend" component can easily also call endpoints or listen for events) but we needed to separate things somehow. However, you can organize your components however you see fit.

For examples using RPC, you need to run the backend first, so that procedures are registered and available to call.

The Examples

Clients

The following examples show two alternative ways of connecting a WAMP client to a WAMP router. This code is also a good starting point for own apps.

Overview Examples

  • LoopingCall: shows an alternative way of publishing periodically

RPC Examples

  • Arguments: different types of argument-passing
  • Complex: complex return types
  • Decorators: register RPC methods using decorators
  • Errors: map custom error classes to WAMP URIs
  • Options: show some RegistrationOptions and CallOptions use
  • Progress: progressive results for long-running oprations
  • Slow Square: an RPC call that takes some time
  • Time Service: XXX delete?

PubSub Examples

  • Basic: publish to a topic once per second
  • Complex: demonstrates different payload arguments
  • Decorators: doing subscriptions with decorators
  • Options: use of PublishOptions and SubscribeOptions
  • Unsubscribe: listen to events for a limited time

App Examples

We still need to explain these. For starters, here's the list:

How to run

See Running the Examples