Skip to content

Latest commit

 

History

History
81 lines (55 loc) · 2.52 KB

File metadata and controls

81 lines (55 loc) · 2.52 KB

Django Channels Example Social Network

This is an example real-time Social built using Django Channels Rest Framework.

See our blog post Build a Realtime Social Network using Django Channels for a detail breakdown of this example.

Running this example server

python manager.py migrate
python manage.py runserver 0.0.0.0:8000

Playing with this example server

This project does not include any frontend elements so you will need to write your own or use a websocket client, like Cleora app.

Logging in

There is a simple example login eondptoin:

GET /login/{username}

This will log you (and create a new user account if the user name does not already exist).

Using the Websocket API

Every message you send from your client to the server should include a request_id. This should be a random string or int. When the server responses you your message it will include the request_id of the request that is is responding to. This is use-full client-side so that you can create a Promise/Futures based api interface.

The consumer uses the action value to determine what action to call from your consumer. The RestApi style mixin actions provided by Django Channels Rest Framework expect additional data for the DjangoRestFramwork sterilisers to be nested within a data property.

Creating a Post

{ "action": "create", "request_id": 42, "data": {"body": "#Django is an epic #Framework for #WedDevelopment"} }

Updating a Post

{ "action": "patch", "request_id": 43, "pk": 3, "data": {"body": "#Django is an epic #Framework for #WedDevelopment"} }

Retrieving a Post

{ "action": "retrieve", "request_id": 44, "pk": 3 }

Deleting a Post

{ "action": "delete", "request_id": 44, "pk": 3 }

Subscribing to a Hashtag

{ "action": "subscribe_to_hashtag", "request_id": 45, "hashtag": "python" }

Un-Subscribing from a Hashtag

{ "action": "unsubscribe_from_hashtag", "request_id": 46, "hashtag": "python" }

Subscribing to all Posts

{ "action": "subscribe_to_list", "request_id": 47}

Un-Subscribing from all Posts

{ "action": "unsubscribe_from_list", "request_id": 48}

Can I just deploy this as is?

No this IS NOT production/deploy ready!