Go to file
2022-03-02 15:18:09 +01:00
.github/workflows chore: update github token secret 2021-06-17 16:11:07 +02:00
cmd/gotsrpc fix: remove demo code 2022-02-17 15:33:46 +01:00
config feat: support union types 2022-03-02 15:18:09 +01:00
example feat: support union types 2022-03-02 15:18:09 +01:00
prometheus chore: change v2 module 2021-05-05 10:44:01 +02:00
.gitignore feat: ignore node modules 2022-03-02 14:52:09 +01:00
.golangci.yaml feat: support union types 2022-03-02 15:18:09 +01:00
.goreleaser.yml chore: add arm64 2021-12-23 11:50:38 +01:00
build.go feat: support union types 2022-03-02 15:18:09 +01:00
client_test.go feat: add context to go client 2021-05-21 14:42:01 +02:00
client.go feat: support union types 2022-03-02 15:18:09 +01:00
clienterror.go feat: support union types 2022-03-02 15:18:09 +01:00
code.go async client flavor added 2018-06-12 14:09:46 +02:00
error.go feat: support union types 2022-03-02 15:18:09 +01:00
go.go feat: support union types 2022-03-02 15:18:09 +01:00
go.mod feat: support union types 2022-03-02 15:18:09 +01:00
go.sum feat: support union types 2022-03-02 15:18:09 +01:00
gorpc.go fixed types 2016-12-17 15:55:32 +01:00
gotsrpc_test.go improved interface{} support and refactored arg loading 2017-07-25 08:46:42 +02:00
gotsrpc.go feat: support union types 2022-03-02 15:18:09 +01:00
http_test.go feat: add http factory to inject global configurators 2018-12-20 11:53:04 +01:00
http.go chore: force connection re-establishment for LB 2019-11-20 14:17:50 +01:00
httperror.go feat: support union types 2022-03-02 15:18:09 +01:00
instrumentation_test.go feat: update go-modules and add objectives to summary vectors (#21) 2019-10-25 12:32:32 +02:00
instrumentation.go feat: update go-modules and add objectives to summary vectors (#21) 2019-10-25 12:32:32 +02:00
Makefile feat: support union types 2022-03-02 15:18:09 +01:00
model.go feat: support union types 2022-03-02 15:18:09 +01:00
reader_test.go chore: change v2 module 2021-05-05 10:44:01 +02:00
README.md feat: replace examples 2022-02-17 14:22:15 +01:00
responsewriter.go feat: don't send reponse on http error 2021-05-21 15:25:09 +02:00
servicereader.go feat: support union types 2022-03-02 15:18:09 +01:00
stats.go added response and request size to stats 2017-01-27 16:59:03 +01:00
transport.go feat: support union types 2022-03-02 15:18:09 +01:00
typereader.go feat: support union types 2022-03-02 15:18:09 +01:00
typescript_test.go async client flavor added 2018-06-12 14:09:46 +02:00
typescript.go feat: support union types 2022-03-02 15:18:09 +01:00
typscriptclient.go feat: support union types 2022-03-02 15:18:09 +01:00
unionext.go feat: support union types 2022-03-02 15:18:09 +01:00

Go / TypeScript and Go / Go RPC

Build Status

Installation

From source to /usr/local/bin/gotsrpc:

go get github.com/foomo/gotsrpc/v2
cd $GOPATH/src/github.com/foomo/gotsrpc
make install

If you trust us there are precompiled versions:

releases

On the mac:

brew install foomo/gotsrpc/gotsrpc

Usage

gotsrpc gotsrpc.yml

Will generate client and server side go and TypeScript code. Have fun!

Configuration Examples

targets:
  demo:
    services:
      /service/foo: Foo
      /service/demo: Demo
    package: github.com/foomo/gotsrpc/v2/demo
    out: /tmp/test.ts
    gorpc:
      - Foo
      - Demo
    tsrpc:
      - Foo
      - Demo

mappings:
  github.com/foomo/gotsrpc/v2/demo:
    out: /tmp/test-files-demo.ts
  github.com/foomo/gotsrpc/v2/demo/nested:
    out: /tmp/test-files-demo-nested.ts
...

Async Example

How to use async clients in this case with axios:

import axios, { AxiosResponse } from "axios";
import { ServiceClient as ExampleClient } from "./some/generated/client";

// axios transport
let getTransport = endpoint => async <T>(method, args = []) => {
	return new Promise<T>(async (resolve, reject) => {
		try {
			let axiosPromise: AxiosResponse<T> = await axios.post<T>(
				endpoint + "/" + encodeURIComponent(method),
				JSON.stringify(args),
			);
			return resolve(axiosPromise.data);
		} catch (e) {
			return reject(e);
		}
	});
};

let client = new ExampleClient(getTransport(ExampleClient.defaultEndpoint));

export async function test() {
	try {
		let result = await client.getResult();
		console.log("here is the result", result);
	} catch (e) {
		// e => network?
		// e => json
		// e => domain error type
		console.error("something went wrong ...", e);
	}
}

GOModule Support

To support go modules add


module:
  name: github.com/foomo/gotsrpc
  path: ../ # Relative Or Absolute Path where the package was checked out (root of the package)