переделал handshake

This commit is contained in:
CupIvan 2018-05-09 15:14:45 +03:00 committed by GitHub
parent f3d0dd3a99
commit dd787da82e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

11
API.md
View File

@ -25,22 +25,23 @@ GUI - примитивная программа под Linux/Window/Android, к
## Протокол обмена ## Протокол обмена
Обмен сообщениями ведётся по GET/POST http протоколу в формате JSON, что позволяет делать GUI прямо в браузере. Обмен сообщениями ведётся по GET/POST http протоколу в формате JSON, что позволяет делать GUI прямо в браузере.
При любой успешной отправке данных обновляем поле last_connect у контакта. При любой успешной отправке данных обновляем поле last_connect у контакта.
Во всех сообщениях нужно указывать ключ, если он не подойдёт - то сообщение отбрасывается. Если пришло сообщение от контакта, которого нет в адресной книге - то оно отбрасывается.
Исключения - запрос handshake.
1. Добавление в друзья 1. Добавление в друзья
Используется, чтобы установить связь с контактом. Для этого запрашиваем у него ключ доступа, предварительно отправив свой. Используется, чтобы установить связь с контактом. Тот кто хочет добавиться в друзья - отправляет такой запрос.
```json ```json
{ "action":"handshake", "key":"пароль" } { "action":"handshake", "nick": "" }
``` ```
ответ ответ
```json ```json
{ "status": 1 } { "status": 1 }
``` ```
Когда один отправил запрос - то второй может отправить свой ключ и тогда сервера смогут общаться друг с другом. У другого абонента висит этот контакт в списке неавторизованных. Если он хочет его тоже добавить в друзья - отправляем ему свой handshake. Возможет вариант, когда сервер автоматически добавляет в друзья (публичный сервер для пересылки offline сообщений).
2. Отправка сообщения: 2. Отправка сообщения:
```json ```json
{ "action":"send", "from":"адрес", "to":"адрес", "message":"сообщение", "timestamp":"время", "enctype":"", "key":"" } { "action":"send", "from":"адрес", "to":"адрес", "message":"сообщение", "timestamp":"время", "enctype":"" }
``` ```
ответ: ответ:
```json ```json