1
0
Fork 0
mirror of https://github.com/anyproto/anytype-heart.git synced 2025-06-09 17:44:59 +09:00
Shared library for Anytype clients https://anytype.io
Find a file
Anastasia Shemyakinskaya 36a1043646
Merge pull request #209 from anyproto/go-1136-columns-with-the-same-names-disappear-csv-import
GO-1136: remove spaces from CSV relations
2023-07-21 12:24:00 +02:00
.githooks GO-879 Add pre-commit secrets linter 2023-04-25 18:17:59 +02:00
.github Update mirror-any-block.yml (#203) 2023-07-20 18:24:25 +03:00
.idea GO-1330 Fix rebase changes 2023-04-25 18:17:59 +02:00
.run GO-1330 Fix rebase changes 2023-05-24 17:10:52 +02:00
app/testapp improve log app start debug 2023-06-23 15:59:36 +02:00
clientlibrary GO-1471 Add service subscription debug method 2023-07-05 15:11:36 +02:00
cmd Merge pull request #201 from anyproto/go-1344-save-stacktrace-on-sigusr1 2023-07-20 12:20:28 +02:00
core GO-1136: fix comments 2023-07-21 11:33:50 +02:00
deps improve makefile and readme 2023-07-17 21:16:43 +02:00
dist fix makefile 2023-06-01 15:56:05 +02:00
docs GO-1720 add networkId to AccountInfo 2023-07-17 22:13:38 +02:00
metrics metrics: remove unused events and amplitude fields 2023-07-06 15:11:00 +01:00
net/addrs GO-1330 Fix rebase changes 2023-05-24 17:10:52 +02:00
pb GO-1710 Add defaultTemplateId to update event 2023-07-17 13:06:54 +02:00
pkg/lib Merge pull request #196 from anyproto/go-1720-provide-the-current-network-id-for-client 2023-07-20 10:46:20 +02:00
space Fix lint 2023-07-04 14:33:44 +02:00
tests GO-1330 Fix rebase changes 2023-05-24 17:10:52 +02:00
util Merge pull request #201 from anyproto/go-1344-save-stacktrace-on-sigusr1 2023-07-20 12:20:28 +02:00
.dockerignore GO-511 Smoke test 2022-12-01 18:16:10 +05:00
.gitattributes lib.so moved to dist/ and updated 2019-09-26 22:56:33 +03:00
.gitignore network config rewritten 2023-07-17 19:58:56 +02:00
.golangci.yml GO-1483: Please linter 2023-06-21 18:25:22 +05:00
.mockery.yaml GO-1482: Object store: full-text tests 2023-06-08 15:51:23 +05:00
.pre-commit-config.yaml GO-879 Add pre-commit secrets linter 2023-04-25 18:17:59 +02:00
build.gradle update maven package name 2023-06-05 15:00:39 +02:00
docker-compose.yml improve makefile and readme 2023-07-17 21:16:43 +02:00
Dockerfile GO-1077: Update Readme and Dockerfile 2023-04-25 18:17:59 +02:00
go.mod improve makefile and readme 2023-07-17 21:16:43 +02:00
go.sum improve makefile and readme 2023-07-17 21:16:43 +02:00
LICENSE.md OPEN-13: License + small instruction updates (#165) 2023-07-10 13:39:57 +03:00
Makefile makefile: remove CGO warnings 2023-07-17 21:43:27 +02:00
package.json GO-1330 Fix rebase changes 2023-05-24 17:10:52 +02:00
README.md Update README.md (#197) 2023-07-20 16:07:34 +03:00
webpack.config.js add webpack umd library options 2020-06-22 16:22:28 +03:00

Anytype Heart

Middleware library for Anytype.

Build from Source

  1. Install Golang 1.19.x from here or using preferred package manager
  2. Follow instructions below for the target systems

Build and install for the desktop client

make install-dev-js — build the local server and copy it and protobuf binding into ../anytype-ts

Parameters:

Build for iOS

Instructions to set up environment for iOS: here

  1. make build-ios to build the framework into dist/ios folder

    Parameters:

  2. make protos-swift to generate swift protobuf bindings into dist/ios/pb

Build for Android

Instructions to setup environment for Android: here

  1. make build-android to build the library into dist/android folder

    Parameters:

  2. make protos-java to generate java protobuf bindings into dist/android/pb

Rebuild protobuf generated files

First, you need to install protobuf pkg using your preferred package manager. This repo uses custom protoc located at anyproto/protobuf. It adds gomobile plugin and some env-controlled options to control the generated code style. This protobuf generator will replace your protoc binary, BTW it doesn't have any breaking changes for other protobuf and grpc code

You can override the binary with a simple command:

make setup-protoc

Then you can easily regenerate proto files:

make protos

Run tests

Install dependencies for running tests and generate mocks:

make test-deps

GO test:

make test

You'll need to install latest (at least clang 15)

brew install llvm 
echo 'export PATH="/<homebrew location>/llvm/bin:$PATH"' >> ~/.zshrc 

Integration tests

First you need to start a docker container via docker-compose:

export ANYTYPE_TEST_GRPC_PORT=31088
docker-compose up -d

Then you can run the basic integration tests:

make test-integration

Run local gRPC server to debug

⚠️ Make sure to update/install protobuf compiler from this repo using make setup-protoc

Commands:

  • make run-server - builds proto files for grpc server, builds the binary and runs it
  • make build-server - builds proto files for grpc server and builds the binary into dist/server

If you want to change the default port(9999):

ANYTYPE_GRPC_ADDR=127.0.0.1:8888 make run-debug


Useful tools for debug

Debug server

Use env var ANYDEBUG=address to enable debugging HTTP server. For example: ANYDEBUG=:6061 will start debug server on port 6061

You can find all endpoints in /debug page. For example: http://localhost:6061/debug

gRPC logging

In order to log mw gRPC requests/responses use ANYTYPE_GRPC_LOG env var:

  • ANYTYPE_LOG_LEVEL="grpc=DEBUG" ANYTYPE_GRPC_LOG=1 - log only method names
  • ANYTYPE_LOG_LEVEL="grpc=DEBUG" ANYTYPE_GRPC_LOG=2 - log method names + payloads for commands
  • ANYTYPE_LOG_LEVEL="grpc=DEBUG" ANYTYPE_GRPC_LOG=2 - log method names + payloads for commands&events

gRPC tracing

  1. Run jaeger UI on the local machine: docker run --rm -d -p6832:6832/udp -p6831:6831/udp -p16686:16686 -p5778:5778 -p5775:5775/udp jaegertracing/all-in-one:latest
  2. Run mw with ANYTYPE_GRPC_TRACE env var:
  • ANYTYPE_GRPC_TRACE=1 - log only method names/times
  • ANYTYPE_GRPC_TRACE=2 - log method names + payloads for commands
  • ANYTYPE_GRPC_TRACE=2 - log method names + payloads for commands&events
  1. Open Jaeger UI at http://localhost:16686

Debug tree

  1. You can use cmd/debugtree.go to perform different operations with tree exported in zip archive (rpc DebugTree)
  2. The usage looks like this go run debugtree.go -j -t -f [path to zip archive] where -t tells the cmd to generate tree graph view and -j - to generate json representation of the tree (i.e. data in each individual block)
  3. You can use flag -r to build the tree from its root, that way you will see all the changes in the tree, and not only those from the common snapshot
  4. For more info please check the command usage in debugtree.go

GUI

https://github.com/uw-labs/bloomrpc

HowTo: Set the import path to the middleware root, then select commands.proto file

CLI

https://github.com/njpatel/grpcc

Running with prometheus and grafana

  • cd metrics/docker cd into folder with docker-compose file
  • docker-compose up - run the prometheus/grafana
  • use ANYTYPE_PROM=0.0.0.0:9094 when running middleware to enable metrics collection. Client commands metrics available only in gRPC mode
  • open http://127.0.0.1:3000 to view collected metrics in Grafana. You can find several dashboards there:
    • MW internal middleware metrics such as changes, added and created threads histograms
    • MW commands server metrics for clients commands. Works only in grpc-server mode

Install local deps (Mac)

As of 16.01.23 last protobuf version (21.12) broke the JS plugin support, so you can use the v3 branch:

brew install protobuf@3

To generate Swift protobuf:

brew install swift-protobuf

Install local deps (Debian-Ubuntu)

We need to have protoc binary (3.x version) and libprotoc headers in orderto build the grpc-web plugin

apt install protobuf-compiler libprotoc-dev

Contribution

Thank you for your desire to develop Anytype together.

Currently, we're not ready to accept PRs, but we will in the nearest future.

Follow us on Github and join the Contributors Community.


Made by Any — a Swiss association 🇨🇭

Licensed under Any Source Available License 1.0.