Skip to content

Commit 0887acf

Browse files
FrandoSimon-Lauxr10sflipsimon
authored
Integrate JSON-RPC API in core (#3463)
* integrate json-rpc repo https://github.com/deltachat/deltachat-jsonrpc * get target dir from cargo * fix clippy * use node 16 in ci use `npm i` instead of `npm ci` try fix ci script and fix a doc comment * fix get_provider_info docs * refactor function name * fix formatting make test pass fix clippy * update .gitignore * change now returns event names as id directly, no conversion method or number ids anymore also longer timeout for requesting test accounts from mailadm * fix compile after rebase * add json api to cffi and expose it in dc node * add some files to npm ignore that don't need to be in the npm package * add jsonrpc crate to set_core_version * add jsonrpc feature flag * call a jsonrpc function in segfault example * break loop on empty response * fix closing segfault thanks again to link2xt for figguring this out * activate other tests again * remove selectAccount from highlevel client * put jsonrpc stuff in own module * disable jsonrpc by default * add @deltachat/jsonrpc-client to make sure its dependencies are installed, too whwn installing dc-node * commit types.ts that dc-node has everything it needs to provide @deltachat/jsonrpc-client without an extra ts compile step * improve naming * Changes for tokio compat, upgrade to yerpc 0.3 This also changes the webserver binary to use axum in place of tide. * Improvements to typescript package * Improve docs. * improve docs, fix example * Fix CFFI for JSON-RPC changes * use stable toolchain not 1.56.0 * fix ci * try to fix ci * remove emtpy file allow unused code for new_from_arc * expose anyhow errors feature name was wrong * use multi-threaded runtime in JSON-RPC webserver * improve test setup and code style * don't wait for IO on webserver start * Bump yerpc to 0.3.1 with fix for axum server * update todo document remove specific api stuff for now, we now have the an incremental aproach on moving not the all at-once effort I though it would be * remove debug logs * changelog entry about the jsonrpc * Fix method name casings and cleanups * Improve JSON-RPC CI, no need to build things multiple times * Naming consistency: Use DeltaChat not Deltachat * Improve documentation * fix docs * adress dig's comments - description in cargo.toml - impl From<EventType> for EventTypeName - rename `CommandApi::new_from_arc` -> `CommandApi::from_arc` - pre-allocate if we know the entry count already - remove unused enumerate - remove unused serde attribute comment - rename `FullChat::from_dc_chat_id` -> `FullChat::try_from_dc_chat_id` * make it more idiomatic: rename `ContactObject::from_dc_contact -> `ContactObject::try_from_dc_contact` * apply link2xt's suggestions: - unref jsonrpc_instance in same thread it was created in - increase `max_queue_size` from 1 to 1000 * reintroduce segfault test script * remove unneeded context thanks to link2xt for pointing that out * Update deltachat-ffi/deltachat.h Co-authored-by: bjoern <[email protected]> * Update deltachat-ffi/deltachat.h Co-authored-by: bjoern <[email protected]> * make sure to use dc_str_unref instead of free on cstrings returned/owned by rust * Increase online test timeouts for CI * fix the typos thanks to ralphtheninja for finding them * restore same configure behaviour as desktop: make configure restart io with the old configuration if it had one on error * found another segfault: this time in batch_set_config * remove print from test * make dcn_json_rpc_request return undefined instead of not returning this might have been the cause for the second segfault * add set_config_from_qr to jsonrpc * add `add_device_message` to jsonrpc * jsonrpc: add `get_fresh_msgs` and `get_fresh_msg_cnt` * jsonrpc: add dm_chat_contact to ChatListItemFetchResult * add webxdc methods to jsonrpc: - `webxdc_send_status_update` - `webxdc_get_status_updates` - `message_get_webxdc_info` * add `chat_get_media` to jsonrpc also add viewtype wrapper enum and use it in `MessageObject`, additionally to using it in `chat_get_media` * use camelCase in all js object properties * Add check_qr function to jsonrpc * Fixed clippy errors and formatting * Fixed formatting * fix changelog ordering after rebase * fix compile after merging in master branch Co-authored-by: Simon Laux <[email protected]> Co-authored-by: Simon Laux <[email protected]> Co-authored-by: bjoern <[email protected]> Co-authored-by: flipsimon <[email protected]>
1 parent 142c02b commit 0887acf

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

55 files changed

+4499
-22
lines changed

.github/workflows/ci.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -131,7 +131,7 @@ jobs:
131131
uses: actions-rs/cargo@v1
132132
with:
133133
command: build
134-
args: -p deltachat_ffi
134+
args: -p deltachat_ffi --features jsonrpc
135135

136136
- name: run python tests
137137
if: ${{ matrix.python }}

.github/workflows/jsonrpc.yml

+45
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
name: JSON-RPC API Test
2+
3+
on:
4+
push:
5+
branches: [master]
6+
pull_request:
7+
branches: [master]
8+
9+
env:
10+
CARGO_TERM_COLOR: always
11+
12+
jobs:
13+
build_and_test:
14+
runs-on: ubuntu-latest
15+
steps:
16+
- uses: actions/checkout@v2
17+
- name: Use Node.js 16.x
18+
uses: actions/setup-node@v1
19+
with:
20+
node-version: 16.x
21+
- uses: actions-rs/toolchain@v1
22+
with:
23+
profile: minimal
24+
toolchain: stable
25+
override: true
26+
- name: Add Rust cache
27+
uses: Swatinem/[email protected]
28+
- name: npm install
29+
run: |
30+
cd deltachat-jsonrpc/typescript
31+
npm install
32+
- name: Build TypeScript, run Rust tests, generate bindings
33+
run: |
34+
cd deltachat-jsonrpc/typescript
35+
npm run build
36+
- name: Run integration tests
37+
run: |
38+
cd deltachat-jsonrpc/typescript
39+
npm run test
40+
env:
41+
DCC_NEW_TMP_EMAIL: ${{ secrets.DCC_NEW_TMP_EMAIL }}
42+
- name: Run linter
43+
run: |
44+
cd deltachat-jsonrpc/typescript
45+
npm run prettier:check

.npmignore

+14
Original file line numberDiff line numberDiff line change
@@ -40,3 +40,17 @@ node/old_docs.md
4040
.vscode/
4141
.github/
4242
node/.prettierrc.yml
43+
44+
deltachat-jsonrpc/TODO.md
45+
deltachat-jsonrpc/README.MD
46+
deltachat-jsonrpc/.gitignore
47+
deltachat-jsonrpc/typescript/.gitignore
48+
deltachat-jsonrpc/typescript/.prettierignore
49+
deltachat-jsonrpc/typescript/accounts/
50+
deltachat-jsonrpc/typescript/index.html
51+
deltachat-jsonrpc/typescript/node-demo.js
52+
deltachat-jsonrpc/typescript/report_api_coverage.mjs
53+
deltachat-jsonrpc/typescript/test
54+
deltachat-jsonrpc/typescript/example.ts
55+
56+
.DS_Store

CHANGELOG.md

+12
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,19 @@
22

33
## Unreleased
44

5+
### API-Changes
6+
- jsonrpc api over websocket server (basically a new api next to the cffi) #3463
7+
- jsonrpc methods in cffi #3463:
8+
- `dc_jsonrpc_instance_t* dc_jsonrpc_init(dc_accounts_t* account_manager);`
9+
- `void dc_jsonrpc_unref(dc_jsonrpc_instance_t* jsonrpc_instance);`
10+
- `void dc_jsonrpc_request(dc_jsonrpc_instance_t* jsonrpc_instance, char* request);`
11+
- `char* dc_jsonrpc_next_response(dc_jsonrpc_instance_t* jsonrpc_instance);`
12+
- node: json rpc methods #3463:
13+
- `AccountManager.prototype.startJsonRpcHandler(callback: ((response: string) => void)): void`
14+
- `AccountManager.prototype.jsonRpcRequest(message: string): void`
15+
516
### Added
17+
- added a JSON RPC API, accessible through a WebSocket server, the CFFI bindings and the Node.js bindings #3463
618

719
### Changes
820

CMakeLists.txt

+1-1
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@ add_custom_command(
2121
PREFIX=${CMAKE_INSTALL_PREFIX}
2222
LIBDIR=${CMAKE_INSTALL_FULL_LIBDIR}
2323
INCLUDEDIR=${CMAKE_INSTALL_FULL_INCLUDEDIR}
24-
${CARGO} build --release --no-default-features
24+
${CARGO} build --release --no-default-features --features jsonrpc
2525

2626
# Build in `deltachat-ffi` directory instead of using
2727
# `--package deltachat_ffi` to avoid feature resolver version

0 commit comments

Comments
 (0)