2023-07-30 01:35:00 +08:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package memos.api.v2;
|
|
|
|
|
|
|
|
import "api/v2/common.proto";
|
2023-08-05 09:32:52 +08:00
|
|
|
import "api/v2/memo_service.proto";
|
2023-07-30 01:35:00 +08:00
|
|
|
import "google/api/annotations.proto";
|
|
|
|
import "google/api/client.proto";
|
2023-09-10 18:56:24 +08:00
|
|
|
import "google/api/field_behavior.proto";
|
|
|
|
import "google/protobuf/timestamp.proto";
|
2023-07-30 01:35:00 +08:00
|
|
|
|
|
|
|
option go_package = "gen/api/v2";
|
|
|
|
|
|
|
|
service UserService {
|
|
|
|
rpc GetUser(GetUserRequest) returns (GetUserResponse) {
|
2023-09-10 18:56:24 +08:00
|
|
|
option (google.api.http) = {get: "/api/v2/users/{username}"};
|
|
|
|
option (google.api.method_signature) = "username";
|
|
|
|
}
|
|
|
|
rpc UpdateUser(UpdateUserRequest) returns (UpdateUserResponse) {
|
2023-09-10 22:03:12 +08:00
|
|
|
option (google.api.http) = {
|
|
|
|
post: "/api/v2/users/{username}"
|
|
|
|
body: "*"
|
|
|
|
};
|
2023-09-10 18:56:24 +08:00
|
|
|
option (google.api.method_signature) = "username";
|
2023-07-30 01:35:00 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
message User {
|
|
|
|
int32 id = 1;
|
|
|
|
|
|
|
|
RowStatus row_status = 2;
|
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
google.protobuf.Timestamp create_time = 3;
|
2023-07-30 01:35:00 +08:00
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
google.protobuf.Timestamp update_time = 4;
|
2023-07-30 01:35:00 +08:00
|
|
|
|
|
|
|
string username = 5;
|
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
enum Role {
|
|
|
|
ROLE_UNSPECIFIED = 0;
|
|
|
|
HOST = 1;
|
|
|
|
ADMIN = 2;
|
|
|
|
USER = 3;
|
|
|
|
}
|
|
|
|
|
2023-07-30 01:35:00 +08:00
|
|
|
Role role = 6;
|
|
|
|
|
|
|
|
string email = 7;
|
|
|
|
|
|
|
|
string nickname = 8;
|
|
|
|
|
|
|
|
string open_id = 9;
|
|
|
|
|
|
|
|
string avatar_url = 10;
|
2023-09-10 18:56:24 +08:00
|
|
|
|
|
|
|
string password = 11 [(google.api.field_behavior) = INPUT_ONLY];
|
2023-07-30 01:35:00 +08:00
|
|
|
}
|
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
message GetUserRequest {
|
|
|
|
string username = 1;
|
|
|
|
}
|
2023-07-30 01:35:00 +08:00
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
message GetUserResponse {
|
|
|
|
User user = 1;
|
|
|
|
}
|
2023-07-30 01:35:00 +08:00
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
message UpdateUserRequest {
|
|
|
|
string username = 1;
|
2023-07-30 01:35:00 +08:00
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
User user = 2;
|
2023-07-30 01:35:00 +08:00
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
// The update mask applies to the user resource.
|
2023-09-10 22:03:12 +08:00
|
|
|
repeated string update_mask = 3;
|
2023-07-30 01:35:00 +08:00
|
|
|
}
|
|
|
|
|
2023-09-10 18:56:24 +08:00
|
|
|
message UpdateUserResponse {
|
2023-07-30 01:35:00 +08:00
|
|
|
User user = 1;
|
|
|
|
}
|
2023-07-30 09:53:24 +08:00
|
|
|
|
|
|
|
message UserSetting {
|
|
|
|
// The user id of the setting.
|
|
|
|
int32 user_id = 1;
|
|
|
|
|
|
|
|
enum Key {
|
|
|
|
KEY_UNSPECIFIED = 0;
|
|
|
|
// The preferred locale.
|
|
|
|
LOCALE = 1;
|
|
|
|
// The preferred appearance.
|
|
|
|
APPEARANCE = 2;
|
|
|
|
// The default visibility of the memo when creating a new memo.
|
|
|
|
MEMO_VISIBILITY = 3;
|
|
|
|
// User's telegram id
|
|
|
|
TELEGRAM_USER_ID = 4;
|
|
|
|
}
|
|
|
|
// The key of the setting.
|
|
|
|
Key key = 2;
|
|
|
|
|
|
|
|
// The value of the setting.
|
|
|
|
UserSettingValue value = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message UserSettingValue {
|
|
|
|
oneof value {
|
|
|
|
// Default value as a string.
|
|
|
|
string string_value = 1;
|
|
|
|
Visibility visibility_value = 2;
|
|
|
|
}
|
|
|
|
}
|