-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
// SPDX-FileCopyrightText: 2025 Shota FUJI <pockawoooh@gmail.com>
// SPDX-License-Identifier: AGPL-3.0-only
edition = "2023";
package yamori.backend.projections.workspace.v1;
import "yamori/backend/workspace/v1/types/v1/permission.proto";
option go_package = "pocka.jp/x/yamori/proto/go/backend/projections/workspace/v1";
// ユーザの一覧。
// ぶっちゃけこれは普通のテーブルにしてもいいが、面倒なので Projection にしてる
// パフォーマンスとかの問題が出てきたら Query 用のテーブルを作って Event -> SQL みたいな
// Projection テーブルにするものいいかもしれない。クエリ・ストレージパフォーマンスと
// マイグレーション容易性の妥協点的な。
message Users {
message PasswordLogin {
bytes hash = 1;
bytes salt = 2;
}
message User {
message CustomAttribute {
string id = 1;
string value = 2;
}
string id = 1;
string name = 2;
string display_name = 3;
PasswordLogin password_login = 4;
bool is_admin = 5;
bytes key_id = 6;
repeated yamori.backend.workspace.v1.types.v1.Permission permissions = 7;
repeated CustomAttribute custom_attributes = 8;
}
repeated User users = 1;
}