framework-agnostic RPC API with a smart auto-generated TypeScript client
Project description
Welcome to synclane
synclane
is a framework-agnostic RPC API with a smart auto-generated
TypeScript client.
Idea
The below must be enough to define an API:
class UserParams(pydantic.BaseModel):
uid: str
class GetUsers(AbstractProcedure):
def call(self, in_: UserParams, context) -> List[UserDetails]:
...
and use an automatically generated frontend TypeScript client:
import { callGetUsers } from "./src/out";
expect(callGetUsers(userParams).$promise).resolves.toEqual(listOfUserDetails);
Benefits
Automated typescript client generation
Of course, it's possible to annotate your API, export an OpenAPI schema and generate a typescript client from it. However it will lack the below nice bits.
Browser Dates done right
Javascript doesn't have a separate date
type, so it uses Date
for both
python's date
and datetime
.
Hence when you pass 2000-01-01
to a browser in New York, the browser will
read it as UTC datetime and then convert it to the local timezone, so it will
give you Dec 31, 1991 7:00PM, which is fine if you wanted to work with a
particular moment in time, but what if you wanted to display someone's date of
birth? That's why lacking date type is a problem.
synclane
will see that you wanted to pass python's date
to the browser and
will automatically prepare it in the browser, so that Jan 1st is preserved in
the case above.
Browser friendly types only
synclane
raises an exception if you use types, which browser won't be able to
understand.
No need to define URLs
Once you name a procedure, e.g. AddUser
, you just get callAddUser
function
in the typescript client. You don't need to define any other identifier like
API endpoint url.
Enums
If your procedure in/out types include enums, they will become available in the typescript client.
Installation
pip install synclane
pydantic is the only dependency.
Usage
- define procedures
- define RPC instance, its error handling method, register procedures and dump TypeScript client code
- connect RPC to an API
- on TypeScript side: import
rpcConfig
and initialize:rpcConfig.url
: url where RPC is listeningrpcConfig.initFetch
(optional): function, which accepts and can mutate fetch options as needed
Example
Step 1: Define procedures
--8<-- "tests/int_tst/main.py:def_procedures"
Step 2: Define RPC, dump TS
--8<-- "tests/int_tst/main.py:def_rpc"
Step 3.a: Connect to Django
/// tab | async rpc
--8<-- "tests/int_tst/main.py:django_async"
///
/// tab | sync rpc
--8<-- "tests/int_tst/main.py:django_sync"
///
Step 3.b: Connect to FastAPI
/// tab | async rpc
--8<-- "tests/int_tst/main.py:fastapi_async"
///
/// tab | async rpc
--8<-- "tests/int_tst/main.py:fastapi_sync"
///
Step 4: Use autogenerated TS client
--8<-- "tests/int_tst/tests/client.test.ts:imports"
--8<-- "tests/int_tst/tests/client.test.ts:rpc_config"
--8<-- "tests/int_tst/tests/client.test.ts:get_user"
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file synclane-0.2.2.tar.gz
.
File metadata
- Download URL: synclane-0.2.2.tar.gz
- Upload date:
- Size: 10.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5703bcc3eb4e960b9cac904c35a27219694f95760bd69cf77a0409083125f6ce |
|
MD5 | f0bcf53bd1279356a1f14b983777a8c0 |
|
BLAKE2b-256 | 9a410a1fe4cac4fdbfddf0e25f4d84193d9f8d53c8d8c0d38fb430a65b39400a |
File details
Details for the file synclane-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: synclane-0.2.2-py3-none-any.whl
- Upload date:
- Size: 11.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2b22fdb2ea7f327a7832e5acffb65dec68cf09b1c9c043ed9814545db3bf8b5d |
|
MD5 | 39f4b0dc17701a0bb8124d3a51ebdd9f |
|
BLAKE2b-256 | 924175523c71be21386d746f0d1aa393f924d9cb07fdd31fb2d557bb8d46bd52 |