api.fabaccess-api/connection.capnp
2020-09-07 17:24:05 +02:00

77 lines
2.6 KiB
Cap'n Proto

# Copyright © 2020 Gregor Reitzenstein
# Licensed under the MIT License:
#
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the "Software"),
# to deal in the Software without restriction, including without limitation
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
# and/or sell copies of the Software, and to permit persons to whom the
# Software is furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included
# in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
# OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
# OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@0x9e1c146a27dcc635;
using Auth = import "auth.capnp";
using Api = import "api.capnp";
struct Message {
union {
greet @0 :Greeting;
# Be polite and say hello to the other end
leave @1 :Leave;
auth @2 :Auth.AuthMessage;
# Start an authenticaion exchange
# TODO: RPC bootstrapping
api @3 :Api.Diflouroborane;
}
}
struct Greeting {
# Be nice and say hello to each other first
# A client sends this message to a server first thing, a server then replies
# similarly
# Hello, I'm …
host @0 :Text; # non-qualified Hostname of the client/server, as applicable
# using the program …
program @1 :Text; # SHOULD be of the form `programname-version`
# and speak the API version …
major @2 :UInt32; # The major part of the API version
minor @3 :UInt32; # The minor part of the API version
}
struct Leave {
# Be nice and tell the other side before aborting a connection
enum Reason {
other @0;
# None of the more specific reasons. An implementation SHOULD provide
# more (human-readable) information in the `message` field.
incompatible @1;
# The API versions are in some way incompatible. Doesn't need much of
# an explanation so an implementation MAY leave the message field
# empty.
}
reason @0 :Reason;
message @1 :Text;
# An implementation SHOULD send a human-readable message along, with the
# exception of reasons that are self-explanatory (e.g. incompatible versions)
}