api.fabaccess-api/connection.capnp
2020-10-23 11:53:23 +02:00

79 lines
2.9 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 Rust = import "rust.capnp";
$Rust.parentModule("schema");
using CSharp = import "csharp.capnp";
$CSharp.namespace("FabAccessAPI.Schema");
using Auth = import "auth.capnp";
using Api = import "api.capnp";
interface Bootstrap {
auth @0 () -> ( auth :Auth.Authentication );
permissions @1 () -> ( permissions :Api.Permissions );
# Permission subsystem to manage permissions and systems underlying the authorization process
machines @2 () -> ( machines :Api.Machines );
# Diflouroborane stores machine¹ information in an opaque internal database. This interface is
# the only stable process of modifying that information
}
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)
}