api.fabaccess-api/main.capnp

33 lines
1.2 KiB
Cap'n Proto
Raw Normal View History

2021-02-01 23:23:12 +01:00
@0xbf017710be5a54ff;
using CSharp = import "programming_language/csharp.capnp";
2020-10-19 01:52:15 +02:00
$CSharp.namespace("FabAccessAPI.Schema");
2021-10-01 20:06:06 +02:00
using Authentication = import "auth.capnp".Authentication;
2021-10-01 20:09:42 +02:00
using Resources = import "resources.capnp".Resources;
2021-10-01 20:06:06 +02:00
using Users = import "users.capnp".Users;
2021-02-01 23:23:12 +01:00
interface Bootstrap
2021-02-01 23:23:12 +01:00
{
2021-10-02 12:18:28 +02:00
mechanisms @0 () -> ( mechs :List(Text) );
# Get a list of Mechanisms this server allows in this context.
2021-02-01 23:23:12 +01:00
2021-10-01 20:06:06 +02:00
createSession @1 ( mechanism :Text, initialData :Data ) -> ( authentication :Authentication );
# Create a new session with the server that you wish to authenticate using `mechanism`.
# If the mechanism is a client-first mechanism you MAY set `initialData` to contain the data you
# want to send. If the mechanism is server-first or you do not wish to send initial data, make
# initialData a NULL-pointer.
}
struct Session {
2021-10-01 20:06:06 +02:00
# An API session with the server. The below capabilities are set to NULL if the authenticated
# user doesn't have permission to access the system in question.
2021-10-02 12:18:28 +02:00
resources @0 :Resources;
2021-10-01 20:09:42 +02:00
# Access to the resources configured.
2021-10-01 20:06:06 +02:00
2021-10-02 12:18:28 +02:00
users @1 :Users;
2021-10-01 20:06:06 +02:00
# User administration. This includes both modifying other users and self-modification, so this
# is allowed for most sessions
}