MCPcopy
hub / github.com/koding/kite

github.com/koding/kite @main sqlite

repository ↗ · DeepWiki ↗
743 symbols 2,661 edges 100 files 317 documented · 43%
README

Kite Micro-Service Framework

Kite is a framework for developing micro-services in Go.

GoDoc Build Status

Kite

Kite is both the name of the framework and the micro-service that is written by using this framework. Basically, Kite is a RPC server as well as a client. It connects to other kites and peers to communicate with each other. They can discover other kites using a service called Kontrol, and communicate with them bidirectionaly. The communication protocol uses a WebSocket (or XHR) as transport in order to allow web applications to connect directly to kites.

Kites can talk with each other by sending dnode messages over a socket session. If the client knows the URL of the server kite it can connect to it directly. If the URL is not known, client can ask for it from Kontrol (Service Discovery).

For more info checkout the blog post at GopherAcademy which explains Kite in more detail: http://blog.gopheracademy.com/birthday-bash-2014/kite-microservice-library/

Install and Usage

Install the package with:

go get github.com/koding/kite

Import it with:

import "github.com/koding/kite"

and use kite as the package name inside the code.

What is Kontrol?

Kontrol is the service registry and authentication service used by Kites. It is itself a kite too.

When a kite starts to run, it can registers itself to Kontrol with the Register() method if wished. That enables others to find it by querying Kontrol. There is also a Proxy Kite for giving public URLs to registered kites.

Query has 7 fields:

/<username>/<environment>/<name>/<version>/<region>/<hostname>/<id>
  • You must at least give the username.
  • The order of the fields is from general to specific.
  • Query cannot contains empty parts between fields.

Installing Kontrol

Install Kontrol:

go get github.com/koding/kite/kontrol/kontrol

Generate keys for the Kite key:

openssl genrsa -out key.pem 2048
openssl rsa -in key.pem -pubout > key_pub.pem

Set environment variables:

KONTROL_PORT=6000
KONTROL_USERNAME="kontrol"
KONTROL_STORAGE="etcd"
KONTROL_KONTROLURL="http://127.0.0.1:6000/kite"
KONTROL_PUBLICKEYFILE="certs/key_pub.pem"
KONTROL_PRIVATEKEYFILE="certs/key.pem"

Generate initial Kite key:

./bin/kontrol -initial

How can I use kites from a browser?

A browser can also be a Kite. It has it's own methods ("log" for logging a message to the console, "alert" for displaying alert to the user, etc.). A connected kite can call methods defined on the webpage.

See kite.js library for more information.

How can I write a new kite?

  • Import kite package.
  • Create a new instance with kite.New().
  • Add your method handlers with k.HandleFunc() or k.Handle().
  • Call k.Run()

Below you can find an example, a math kite which calculates the square of a received number:

package main

import "github.com/koding/kite"

func main() {
    // Create a kite
    k := kite.New("math", "1.0.0")

    // Add our handler method with the name "square"
    k.HandleFunc("square", func(r *kite.Request) (interface{}, error) {
        a := r.Args.One().MustFloat64()
        result := a * a    // calculate the square
        return result, nil // send back the result
    }).DisableAuthentication()

    // Attach to a server with port 3636 and run it
    k.Config.Port = 3636
    k.Run()
}

Now let's connect to it and send a 4 as an argument.

package main

import (
    "fmt"

    "github.com/koding/kite"
)

func main() {
    k := kite.New("exp2", "1.0.0")

    // Connect to our math kite
    mathWorker := k.NewClient("http://localhost:3636/kite")
    mathWorker.Dial()

    response, _ := mathWorker.Tell("square", 4) // call "square" method with argument 4
    fmt.Println("result:", response.MustFloat64())
}

Check out the examples folder for more examples.

Extension points exported contracts — how you extend this code

KeyPairStorage (Interface)
KeyPairStorage is responsible of managing key pairs [3 implementers]
kontrol/keypair.go
Handler (Interface)
Objects implementing the Handler interface can be registered to a method. The returned result must be marshalable with j [2 …
method.go
Storage (Interface)
Storage is an interface to a kite storage. A storage should be safe to concurrent access. [2 implementers]
kontrol/storage.go
Logger (Interface)
Logger is the interface used to log messages in different levels.
logger.go
HandlerFunc (FuncType)
HandlerFunc is a type adapter to allow the use of ordinary functions as Kite handlers. If h is a function with the appro
method.go
FinalFunc (FuncType)
FinalFunc represents a proxy function that is called last in the method call chain, regardless whether whole call chaine
method.go

Core symbols most depended-on inside this repo

Error
called by 192
logger.go
Fatal
called by 90
logger.go
String
called by 60
kontrol/kontrol.go
HandleFunc
called by 42
method.go
Info
called by 37
logger.go
TellWithTimeout
called by 37
client.go
Unmarshal
called by 36
dnode/partial.go
Debug
called by 30
logger.go

Shape

Method 397
Function 222
Struct 106
TypeAlias 7
Interface 6
FuncType 5

Languages

Go99%
Python1%

Modules by API surface

client.go55 symbols
kite.go28 symbols
method.go24 symbols
kontrol/kontrol.go24 symbols
kontrol/keypair.go23 symbols
sockjsclient/xhr.go22 symbols
dnode/partial.go21 symbols
sockjsclient/sockjsclient.go19 symbols
kontrol/helper_test.go19 symbols
protocol/protocol.go18 symbols
kontrolclient.go18 symbols
kontrol/postgres.go18 symbols

Datastores touched

kontrolDatabase · 1 repos

For agents

$ claude mcp add kite \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact