mirror of
https://github.com/usememos/memos.git
synced 2025-04-03 04:11:20 +02:00
chore: update user v2 api
This commit is contained in:
parent
866937787c
commit
93f062d0b9
@ -15,3 +15,14 @@ func convertRowStatusFromStore(rowStatus store.RowStatus) apiv2pb.RowStatus {
|
|||||||
return apiv2pb.RowStatus_ROW_STATUS_UNSPECIFIED
|
return apiv2pb.RowStatus_ROW_STATUS_UNSPECIFIED
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func convertRowStatusToStore(rowStatus apiv2pb.RowStatus) store.RowStatus {
|
||||||
|
switch rowStatus {
|
||||||
|
case apiv2pb.RowStatus_ACTIVE:
|
||||||
|
return store.Normal
|
||||||
|
case apiv2pb.RowStatus_ARCHIVED:
|
||||||
|
return store.Archived
|
||||||
|
default:
|
||||||
|
return store.Normal
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -2,11 +2,17 @@ package v2
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"net/http"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/labstack/echo/v4"
|
||||||
|
"github.com/usememos/memos/common/util"
|
||||||
apiv2pb "github.com/usememos/memos/proto/gen/api/v2"
|
apiv2pb "github.com/usememos/memos/proto/gen/api/v2"
|
||||||
"github.com/usememos/memos/store"
|
"github.com/usememos/memos/store"
|
||||||
|
"golang.org/x/crypto/bcrypt"
|
||||||
"google.golang.org/grpc/codes"
|
"google.golang.org/grpc/codes"
|
||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
|
"google.golang.org/protobuf/types/known/timestamppb"
|
||||||
)
|
)
|
||||||
|
|
||||||
type UserService struct {
|
type UserService struct {
|
||||||
@ -24,18 +30,24 @@ func NewUserService(store *store.Store) *UserService {
|
|||||||
|
|
||||||
func (s *UserService) GetUser(ctx context.Context, request *apiv2pb.GetUserRequest) (*apiv2pb.GetUserResponse, error) {
|
func (s *UserService) GetUser(ctx context.Context, request *apiv2pb.GetUserRequest) (*apiv2pb.GetUserResponse, error) {
|
||||||
user, err := s.Store.GetUser(ctx, &store.FindUser{
|
user, err := s.Store.GetUser(ctx, &store.FindUser{
|
||||||
Username: &request.Name,
|
Username: &request.Username,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, status.Errorf(codes.Internal, "failed to list tags: %v", err)
|
return nil, status.Errorf(codes.Internal, "failed to get user: %v", err)
|
||||||
}
|
}
|
||||||
if user == nil {
|
if user == nil {
|
||||||
return nil, status.Errorf(codes.NotFound, "user not found")
|
return nil, status.Errorf(codes.NotFound, "user not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
userMessage := convertUserFromStore(user)
|
userMessage := convertUserFromStore(user)
|
||||||
// Data desensitization.
|
userIDPtr := ctx.Value(UserIDContextKey)
|
||||||
userMessage.OpenId = ""
|
if userIDPtr != nil {
|
||||||
|
userID := userIDPtr.(int32)
|
||||||
|
if userID != userMessage.Id {
|
||||||
|
// Data desensitization.
|
||||||
|
userMessage.OpenId = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
response := &apiv2pb.GetUserResponse{
|
response := &apiv2pb.GetUserResponse{
|
||||||
User: userMessage,
|
User: userMessage,
|
||||||
@ -43,31 +55,105 @@ func (s *UserService) GetUser(ctx context.Context, request *apiv2pb.GetUserReque
|
|||||||
return response, nil
|
return response, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *UserService) UpdateUser(ctx context.Context, request *apiv2pb.UpdateUserRequest) (*apiv2pb.UpdateUserResponse, error) {
|
||||||
|
userID := ctx.Value(UserIDContextKey).(int32)
|
||||||
|
currentUser, err := s.Store.GetUser(ctx, &store.FindUser{
|
||||||
|
ID: &userID,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, status.Errorf(codes.Internal, "failed to get user: %v", err)
|
||||||
|
}
|
||||||
|
if currentUser == nil || (currentUser.ID != userID && currentUser.Role != store.RoleAdmin) {
|
||||||
|
return nil, status.Errorf(codes.PermissionDenied, "permission denied")
|
||||||
|
}
|
||||||
|
if request.UpdateMask == nil || len(request.UpdateMask.Paths) == 0 {
|
||||||
|
return nil, status.Errorf(codes.InvalidArgument, "update mask is empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
currentTs := time.Now().Unix()
|
||||||
|
update := &store.UpdateUser{
|
||||||
|
ID: userID,
|
||||||
|
UpdatedTs: ¤tTs,
|
||||||
|
}
|
||||||
|
for _, path := range request.UpdateMask.Paths {
|
||||||
|
if path == "username" {
|
||||||
|
update.Username = &request.User.Username
|
||||||
|
} else if path == "nickname" {
|
||||||
|
update.Nickname = &request.User.Nickname
|
||||||
|
} else if path == "email" {
|
||||||
|
update.Email = &request.User.Email
|
||||||
|
} else if path == "avatar_url" {
|
||||||
|
update.AvatarURL = &request.User.AvatarUrl
|
||||||
|
} else if path == "role" {
|
||||||
|
role := convertUserRoleToStore(request.User.Role)
|
||||||
|
update.Role = &role
|
||||||
|
} else if path == "reset_open_id" {
|
||||||
|
openID := util.GenUUID()
|
||||||
|
update.OpenID = &openID
|
||||||
|
} else if path == "password" {
|
||||||
|
passwordHash, err := bcrypt.GenerateFromPassword([]byte(request.User.Password), bcrypt.DefaultCost)
|
||||||
|
if err != nil {
|
||||||
|
return nil, echo.NewHTTPError(http.StatusInternalServerError, "failed to generate password hash").SetInternal(err)
|
||||||
|
}
|
||||||
|
passwordHashStr := string(passwordHash)
|
||||||
|
update.PasswordHash = &passwordHashStr
|
||||||
|
} else if path == "row_status" {
|
||||||
|
rowStatus := convertRowStatusToStore(request.User.RowStatus)
|
||||||
|
update.RowStatus = &rowStatus
|
||||||
|
} else {
|
||||||
|
return nil, status.Errorf(codes.InvalidArgument, "invalid update path: %s", path)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
user, err := s.Store.UpdateUser(ctx, update)
|
||||||
|
if err != nil {
|
||||||
|
return nil, status.Errorf(codes.Internal, "failed to update user: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
response := &apiv2pb.UpdateUserResponse{
|
||||||
|
User: convertUserFromStore(user),
|
||||||
|
}
|
||||||
|
return response, nil
|
||||||
|
}
|
||||||
|
|
||||||
func convertUserFromStore(user *store.User) *apiv2pb.User {
|
func convertUserFromStore(user *store.User) *apiv2pb.User {
|
||||||
return &apiv2pb.User{
|
return &apiv2pb.User{
|
||||||
Id: int32(user.ID),
|
Id: int32(user.ID),
|
||||||
RowStatus: convertRowStatusFromStore(user.RowStatus),
|
RowStatus: convertRowStatusFromStore(user.RowStatus),
|
||||||
CreatedTs: user.CreatedTs,
|
CreateTime: timestamppb.New(time.Unix(user.CreatedTs, 0)),
|
||||||
UpdatedTs: user.UpdatedTs,
|
UpdateTime: timestamppb.New(time.Unix(user.UpdatedTs, 0)),
|
||||||
Username: user.Username,
|
Username: user.Username,
|
||||||
Role: convertUserRoleFromStore(user.Role),
|
Role: convertUserRoleFromStore(user.Role),
|
||||||
Email: user.Email,
|
Email: user.Email,
|
||||||
Nickname: user.Nickname,
|
Nickname: user.Nickname,
|
||||||
OpenId: user.OpenID,
|
OpenId: user.OpenID,
|
||||||
AvatarUrl: user.AvatarURL,
|
AvatarUrl: user.AvatarURL,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func convertUserRoleFromStore(role store.Role) apiv2pb.Role {
|
func convertUserRoleFromStore(role store.Role) apiv2pb.User_Role {
|
||||||
switch role {
|
switch role {
|
||||||
case store.RoleHost:
|
case store.RoleHost:
|
||||||
return apiv2pb.Role_HOST
|
return apiv2pb.User_HOST
|
||||||
case store.RoleAdmin:
|
case store.RoleAdmin:
|
||||||
return apiv2pb.Role_ADMIN
|
return apiv2pb.User_ADMIN
|
||||||
case store.RoleUser:
|
case store.RoleUser:
|
||||||
return apiv2pb.Role_USER
|
return apiv2pb.User_USER
|
||||||
default:
|
default:
|
||||||
return apiv2pb.Role_ROLE_UNSPECIFIED
|
return apiv2pb.User_ROLE_UNSPECIFIED
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func convertUserRoleToStore(role apiv2pb.User_Role) store.Role {
|
||||||
|
switch role {
|
||||||
|
case apiv2pb.User_HOST:
|
||||||
|
return store.RoleHost
|
||||||
|
case apiv2pb.User_ADMIN:
|
||||||
|
return store.RoleAdmin
|
||||||
|
case apiv2pb.User_USER:
|
||||||
|
return store.RoleUser
|
||||||
|
default:
|
||||||
|
return store.RoleUser
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,13 +6,20 @@ import "api/v2/common.proto";
|
|||||||
import "api/v2/memo_service.proto";
|
import "api/v2/memo_service.proto";
|
||||||
import "google/api/annotations.proto";
|
import "google/api/annotations.proto";
|
||||||
import "google/api/client.proto";
|
import "google/api/client.proto";
|
||||||
|
import "google/api/field_behavior.proto";
|
||||||
|
import "google/protobuf/field_mask.proto";
|
||||||
|
import "google/protobuf/timestamp.proto";
|
||||||
|
|
||||||
option go_package = "gen/api/v2";
|
option go_package = "gen/api/v2";
|
||||||
|
|
||||||
service UserService {
|
service UserService {
|
||||||
rpc GetUser(GetUserRequest) returns (GetUserResponse) {
|
rpc GetUser(GetUserRequest) returns (GetUserResponse) {
|
||||||
option (google.api.http) = {get: "/api/v2/users/{name}"};
|
option (google.api.http) = {get: "/api/v2/users/{username}"};
|
||||||
option (google.api.method_signature) = "name";
|
option (google.api.method_signature) = "username";
|
||||||
|
}
|
||||||
|
rpc UpdateUser(UpdateUserRequest) returns (UpdateUserResponse) {
|
||||||
|
option (google.api.http) = {patch: "/api/v2/users/{username}"};
|
||||||
|
option (google.api.method_signature) = "username";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -21,12 +28,19 @@ message User {
|
|||||||
|
|
||||||
RowStatus row_status = 2;
|
RowStatus row_status = 2;
|
||||||
|
|
||||||
int64 created_ts = 3;
|
google.protobuf.Timestamp create_time = 3;
|
||||||
|
|
||||||
int64 updated_ts = 4;
|
google.protobuf.Timestamp update_time = 4;
|
||||||
|
|
||||||
string username = 5;
|
string username = 5;
|
||||||
|
|
||||||
|
enum Role {
|
||||||
|
ROLE_UNSPECIFIED = 0;
|
||||||
|
HOST = 1;
|
||||||
|
ADMIN = 2;
|
||||||
|
USER = 3;
|
||||||
|
}
|
||||||
|
|
||||||
Role role = 6;
|
Role role = 6;
|
||||||
|
|
||||||
string email = 7;
|
string email = 7;
|
||||||
@ -36,26 +50,31 @@ message User {
|
|||||||
string open_id = 9;
|
string open_id = 9;
|
||||||
|
|
||||||
string avatar_url = 10;
|
string avatar_url = 10;
|
||||||
}
|
|
||||||
|
|
||||||
enum Role {
|
string password = 11 [(google.api.field_behavior) = INPUT_ONLY];
|
||||||
ROLE_UNSPECIFIED = 0;
|
|
||||||
|
|
||||||
HOST = 1;
|
|
||||||
|
|
||||||
ADMIN = 2;
|
|
||||||
|
|
||||||
USER = 3;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
message GetUserRequest {
|
message GetUserRequest {
|
||||||
string name = 1;
|
string username = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
message GetUserResponse {
|
message GetUserResponse {
|
||||||
User user = 1;
|
User user = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message UpdateUserRequest {
|
||||||
|
string username = 1;
|
||||||
|
|
||||||
|
User user = 2;
|
||||||
|
|
||||||
|
// The update mask applies to the user resource.
|
||||||
|
google.protobuf.FieldMask update_mask = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message UpdateUserResponse {
|
||||||
|
User user = 1;
|
||||||
|
}
|
||||||
|
|
||||||
message UserSetting {
|
message UserSetting {
|
||||||
// The user id of the setting.
|
// The user id of the setting.
|
||||||
int32 user_id = 1;
|
int32 user_id = 1;
|
||||||
|
@ -36,11 +36,13 @@
|
|||||||
- [api/v2/user_service.proto](#api_v2_user_service-proto)
|
- [api/v2/user_service.proto](#api_v2_user_service-proto)
|
||||||
- [GetUserRequest](#memos-api-v2-GetUserRequest)
|
- [GetUserRequest](#memos-api-v2-GetUserRequest)
|
||||||
- [GetUserResponse](#memos-api-v2-GetUserResponse)
|
- [GetUserResponse](#memos-api-v2-GetUserResponse)
|
||||||
|
- [UpdateUserRequest](#memos-api-v2-UpdateUserRequest)
|
||||||
|
- [UpdateUserResponse](#memos-api-v2-UpdateUserResponse)
|
||||||
- [User](#memos-api-v2-User)
|
- [User](#memos-api-v2-User)
|
||||||
- [UserSetting](#memos-api-v2-UserSetting)
|
- [UserSetting](#memos-api-v2-UserSetting)
|
||||||
- [UserSettingValue](#memos-api-v2-UserSettingValue)
|
- [UserSettingValue](#memos-api-v2-UserSettingValue)
|
||||||
|
|
||||||
- [Role](#memos-api-v2-Role)
|
- [User.Role](#memos-api-v2-User-Role)
|
||||||
- [UserSetting.Key](#memos-api-v2-UserSetting-Key)
|
- [UserSetting.Key](#memos-api-v2-UserSetting-Key)
|
||||||
|
|
||||||
- [UserService](#memos-api-v2-UserService)
|
- [UserService](#memos-api-v2-UserService)
|
||||||
@ -395,7 +397,7 @@
|
|||||||
|
|
||||||
| Field | Type | Label | Description |
|
| Field | Type | Label | Description |
|
||||||
| ----- | ---- | ----- | ----------- |
|
| ----- | ---- | ----- | ----------- |
|
||||||
| name | [string](#string) | | |
|
| username | [string](#string) | | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -417,6 +419,38 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="memos-api-v2-UpdateUserRequest"></a>
|
||||||
|
|
||||||
|
### UpdateUserRequest
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Field | Type | Label | Description |
|
||||||
|
| ----- | ---- | ----- | ----------- |
|
||||||
|
| username | [string](#string) | | |
|
||||||
|
| user | [User](#memos-api-v2-User) | | |
|
||||||
|
| update_mask | [google.protobuf.FieldMask](#google-protobuf-FieldMask) | | The update mask applies to the user resource. |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="memos-api-v2-UpdateUserResponse"></a>
|
||||||
|
|
||||||
|
### UpdateUserResponse
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Field | Type | Label | Description |
|
||||||
|
| ----- | ---- | ----- | ----------- |
|
||||||
|
| user | [User](#memos-api-v2-User) | | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="memos-api-v2-User"></a>
|
<a name="memos-api-v2-User"></a>
|
||||||
|
|
||||||
### User
|
### User
|
||||||
@ -427,14 +461,15 @@
|
|||||||
| ----- | ---- | ----- | ----------- |
|
| ----- | ---- | ----- | ----------- |
|
||||||
| id | [int32](#int32) | | |
|
| id | [int32](#int32) | | |
|
||||||
| row_status | [RowStatus](#memos-api-v2-RowStatus) | | |
|
| row_status | [RowStatus](#memos-api-v2-RowStatus) | | |
|
||||||
| created_ts | [int64](#int64) | | |
|
| create_time | [google.protobuf.Timestamp](#google-protobuf-Timestamp) | | |
|
||||||
| updated_ts | [int64](#int64) | | |
|
| update_time | [google.protobuf.Timestamp](#google-protobuf-Timestamp) | | |
|
||||||
| username | [string](#string) | | |
|
| username | [string](#string) | | |
|
||||||
| role | [Role](#memos-api-v2-Role) | | |
|
| role | [User.Role](#memos-api-v2-User-Role) | | |
|
||||||
| email | [string](#string) | | |
|
| email | [string](#string) | | |
|
||||||
| nickname | [string](#string) | | |
|
| nickname | [string](#string) | | |
|
||||||
| open_id | [string](#string) | | |
|
| open_id | [string](#string) | | |
|
||||||
| avatar_url | [string](#string) | | |
|
| avatar_url | [string](#string) | | |
|
||||||
|
| password | [string](#string) | | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -476,9 +511,9 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="memos-api-v2-Role"></a>
|
<a name="memos-api-v2-User-Role"></a>
|
||||||
|
|
||||||
### Role
|
### User.Role
|
||||||
|
|
||||||
|
|
||||||
| Name | Number | Description |
|
| Name | Number | Description |
|
||||||
@ -517,6 +552,7 @@
|
|||||||
| Method Name | Request Type | Response Type | Description |
|
| Method Name | Request Type | Response Type | Description |
|
||||||
| ----------- | ------------ | ------------- | ------------|
|
| ----------- | ------------ | ------------- | ------------|
|
||||||
| GetUser | [GetUserRequest](#memos-api-v2-GetUserRequest) | [GetUserResponse](#memos-api-v2-GetUserResponse) | |
|
| GetUser | [GetUserRequest](#memos-api-v2-GetUserRequest) | [GetUserResponse](#memos-api-v2-GetUserResponse) | |
|
||||||
|
| UpdateUser | [UpdateUserRequest](#memos-api-v2-UpdateUserRequest) | [UpdateUserResponse](#memos-api-v2-UpdateUserResponse) | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -10,6 +10,8 @@ import (
|
|||||||
_ "google.golang.org/genproto/googleapis/api/annotations"
|
_ "google.golang.org/genproto/googleapis/api/annotations"
|
||||||
protoreflect "google.golang.org/protobuf/reflect/protoreflect"
|
protoreflect "google.golang.org/protobuf/reflect/protoreflect"
|
||||||
protoimpl "google.golang.org/protobuf/runtime/protoimpl"
|
protoimpl "google.golang.org/protobuf/runtime/protoimpl"
|
||||||
|
fieldmaskpb "google.golang.org/protobuf/types/known/fieldmaskpb"
|
||||||
|
timestamppb "google.golang.org/protobuf/types/known/timestamppb"
|
||||||
reflect "reflect"
|
reflect "reflect"
|
||||||
sync "sync"
|
sync "sync"
|
||||||
)
|
)
|
||||||
@ -21,24 +23,24 @@ const (
|
|||||||
_ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
|
_ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
|
||||||
)
|
)
|
||||||
|
|
||||||
type Role int32
|
type User_Role int32
|
||||||
|
|
||||||
const (
|
const (
|
||||||
Role_ROLE_UNSPECIFIED Role = 0
|
User_ROLE_UNSPECIFIED User_Role = 0
|
||||||
Role_HOST Role = 1
|
User_HOST User_Role = 1
|
||||||
Role_ADMIN Role = 2
|
User_ADMIN User_Role = 2
|
||||||
Role_USER Role = 3
|
User_USER User_Role = 3
|
||||||
)
|
)
|
||||||
|
|
||||||
// Enum value maps for Role.
|
// Enum value maps for User_Role.
|
||||||
var (
|
var (
|
||||||
Role_name = map[int32]string{
|
User_Role_name = map[int32]string{
|
||||||
0: "ROLE_UNSPECIFIED",
|
0: "ROLE_UNSPECIFIED",
|
||||||
1: "HOST",
|
1: "HOST",
|
||||||
2: "ADMIN",
|
2: "ADMIN",
|
||||||
3: "USER",
|
3: "USER",
|
||||||
}
|
}
|
||||||
Role_value = map[string]int32{
|
User_Role_value = map[string]int32{
|
||||||
"ROLE_UNSPECIFIED": 0,
|
"ROLE_UNSPECIFIED": 0,
|
||||||
"HOST": 1,
|
"HOST": 1,
|
||||||
"ADMIN": 2,
|
"ADMIN": 2,
|
||||||
@ -46,31 +48,31 @@ var (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
func (x Role) Enum() *Role {
|
func (x User_Role) Enum() *User_Role {
|
||||||
p := new(Role)
|
p := new(User_Role)
|
||||||
*p = x
|
*p = x
|
||||||
return p
|
return p
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x Role) String() string {
|
func (x User_Role) String() string {
|
||||||
return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x))
|
return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (Role) Descriptor() protoreflect.EnumDescriptor {
|
func (User_Role) Descriptor() protoreflect.EnumDescriptor {
|
||||||
return file_api_v2_user_service_proto_enumTypes[0].Descriptor()
|
return file_api_v2_user_service_proto_enumTypes[0].Descriptor()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (Role) Type() protoreflect.EnumType {
|
func (User_Role) Type() protoreflect.EnumType {
|
||||||
return &file_api_v2_user_service_proto_enumTypes[0]
|
return &file_api_v2_user_service_proto_enumTypes[0]
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x Role) Number() protoreflect.EnumNumber {
|
func (x User_Role) Number() protoreflect.EnumNumber {
|
||||||
return protoreflect.EnumNumber(x)
|
return protoreflect.EnumNumber(x)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deprecated: Use Role.Descriptor instead.
|
// Deprecated: Use User_Role.Descriptor instead.
|
||||||
func (Role) EnumDescriptor() ([]byte, []int) {
|
func (User_Role) EnumDescriptor() ([]byte, []int) {
|
||||||
return file_api_v2_user_service_proto_rawDescGZIP(), []int{0}
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{0, 0}
|
||||||
}
|
}
|
||||||
|
|
||||||
type UserSetting_Key int32
|
type UserSetting_Key int32
|
||||||
@ -129,7 +131,7 @@ func (x UserSetting_Key) Number() protoreflect.EnumNumber {
|
|||||||
|
|
||||||
// Deprecated: Use UserSetting_Key.Descriptor instead.
|
// Deprecated: Use UserSetting_Key.Descriptor instead.
|
||||||
func (UserSetting_Key) EnumDescriptor() ([]byte, []int) {
|
func (UserSetting_Key) EnumDescriptor() ([]byte, []int) {
|
||||||
return file_api_v2_user_service_proto_rawDescGZIP(), []int{3, 0}
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{5, 0}
|
||||||
}
|
}
|
||||||
|
|
||||||
type User struct {
|
type User struct {
|
||||||
@ -137,16 +139,17 @@ type User struct {
|
|||||||
sizeCache protoimpl.SizeCache
|
sizeCache protoimpl.SizeCache
|
||||||
unknownFields protoimpl.UnknownFields
|
unknownFields protoimpl.UnknownFields
|
||||||
|
|
||||||
Id int32 `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"`
|
Id int32 `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"`
|
||||||
RowStatus RowStatus `protobuf:"varint,2,opt,name=row_status,json=rowStatus,proto3,enum=memos.api.v2.RowStatus" json:"row_status,omitempty"`
|
RowStatus RowStatus `protobuf:"varint,2,opt,name=row_status,json=rowStatus,proto3,enum=memos.api.v2.RowStatus" json:"row_status,omitempty"`
|
||||||
CreatedTs int64 `protobuf:"varint,3,opt,name=created_ts,json=createdTs,proto3" json:"created_ts,omitempty"`
|
CreateTime *timestamppb.Timestamp `protobuf:"bytes,3,opt,name=create_time,json=createTime,proto3" json:"create_time,omitempty"`
|
||||||
UpdatedTs int64 `protobuf:"varint,4,opt,name=updated_ts,json=updatedTs,proto3" json:"updated_ts,omitempty"`
|
UpdateTime *timestamppb.Timestamp `protobuf:"bytes,4,opt,name=update_time,json=updateTime,proto3" json:"update_time,omitempty"`
|
||||||
Username string `protobuf:"bytes,5,opt,name=username,proto3" json:"username,omitempty"`
|
Username string `protobuf:"bytes,5,opt,name=username,proto3" json:"username,omitempty"`
|
||||||
Role Role `protobuf:"varint,6,opt,name=role,proto3,enum=memos.api.v2.Role" json:"role,omitempty"`
|
Role User_Role `protobuf:"varint,6,opt,name=role,proto3,enum=memos.api.v2.User_Role" json:"role,omitempty"`
|
||||||
Email string `protobuf:"bytes,7,opt,name=email,proto3" json:"email,omitempty"`
|
Email string `protobuf:"bytes,7,opt,name=email,proto3" json:"email,omitempty"`
|
||||||
Nickname string `protobuf:"bytes,8,opt,name=nickname,proto3" json:"nickname,omitempty"`
|
Nickname string `protobuf:"bytes,8,opt,name=nickname,proto3" json:"nickname,omitempty"`
|
||||||
OpenId string `protobuf:"bytes,9,opt,name=open_id,json=openId,proto3" json:"open_id,omitempty"`
|
OpenId string `protobuf:"bytes,9,opt,name=open_id,json=openId,proto3" json:"open_id,omitempty"`
|
||||||
AvatarUrl string `protobuf:"bytes,10,opt,name=avatar_url,json=avatarUrl,proto3" json:"avatar_url,omitempty"`
|
AvatarUrl string `protobuf:"bytes,10,opt,name=avatar_url,json=avatarUrl,proto3" json:"avatar_url,omitempty"`
|
||||||
|
Password string `protobuf:"bytes,11,opt,name=password,proto3" json:"password,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) Reset() {
|
func (x *User) Reset() {
|
||||||
@ -195,18 +198,18 @@ func (x *User) GetRowStatus() RowStatus {
|
|||||||
return RowStatus_ROW_STATUS_UNSPECIFIED
|
return RowStatus_ROW_STATUS_UNSPECIFIED
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) GetCreatedTs() int64 {
|
func (x *User) GetCreateTime() *timestamppb.Timestamp {
|
||||||
if x != nil {
|
if x != nil {
|
||||||
return x.CreatedTs
|
return x.CreateTime
|
||||||
}
|
}
|
||||||
return 0
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) GetUpdatedTs() int64 {
|
func (x *User) GetUpdateTime() *timestamppb.Timestamp {
|
||||||
if x != nil {
|
if x != nil {
|
||||||
return x.UpdatedTs
|
return x.UpdateTime
|
||||||
}
|
}
|
||||||
return 0
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) GetUsername() string {
|
func (x *User) GetUsername() string {
|
||||||
@ -216,11 +219,11 @@ func (x *User) GetUsername() string {
|
|||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) GetRole() Role {
|
func (x *User) GetRole() User_Role {
|
||||||
if x != nil {
|
if x != nil {
|
||||||
return x.Role
|
return x.Role
|
||||||
}
|
}
|
||||||
return Role_ROLE_UNSPECIFIED
|
return User_ROLE_UNSPECIFIED
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *User) GetEmail() string {
|
func (x *User) GetEmail() string {
|
||||||
@ -251,12 +254,19 @@ func (x *User) GetAvatarUrl() string {
|
|||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (x *User) GetPassword() string {
|
||||||
|
if x != nil {
|
||||||
|
return x.Password
|
||||||
|
}
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
type GetUserRequest struct {
|
type GetUserRequest struct {
|
||||||
state protoimpl.MessageState
|
state protoimpl.MessageState
|
||||||
sizeCache protoimpl.SizeCache
|
sizeCache protoimpl.SizeCache
|
||||||
unknownFields protoimpl.UnknownFields
|
unknownFields protoimpl.UnknownFields
|
||||||
|
|
||||||
Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
|
Username string `protobuf:"bytes,1,opt,name=username,proto3" json:"username,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *GetUserRequest) Reset() {
|
func (x *GetUserRequest) Reset() {
|
||||||
@ -291,9 +301,9 @@ func (*GetUserRequest) Descriptor() ([]byte, []int) {
|
|||||||
return file_api_v2_user_service_proto_rawDescGZIP(), []int{1}
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{1}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *GetUserRequest) GetName() string {
|
func (x *GetUserRequest) GetUsername() string {
|
||||||
if x != nil {
|
if x != nil {
|
||||||
return x.Name
|
return x.Username
|
||||||
}
|
}
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
@ -345,6 +355,117 @@ func (x *GetUserResponse) GetUser() *User {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type UpdateUserRequest struct {
|
||||||
|
state protoimpl.MessageState
|
||||||
|
sizeCache protoimpl.SizeCache
|
||||||
|
unknownFields protoimpl.UnknownFields
|
||||||
|
|
||||||
|
Username string `protobuf:"bytes,1,opt,name=username,proto3" json:"username,omitempty"`
|
||||||
|
User *User `protobuf:"bytes,2,opt,name=user,proto3" json:"user,omitempty"`
|
||||||
|
// The update mask applies to the user resource.
|
||||||
|
UpdateMask *fieldmaskpb.FieldMask `protobuf:"bytes,3,opt,name=update_mask,json=updateMask,proto3" json:"update_mask,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) Reset() {
|
||||||
|
*x = UpdateUserRequest{}
|
||||||
|
if protoimpl.UnsafeEnabled {
|
||||||
|
mi := &file_api_v2_user_service_proto_msgTypes[3]
|
||||||
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
|
ms.StoreMessageInfo(mi)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) String() string {
|
||||||
|
return protoimpl.X.MessageStringOf(x)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*UpdateUserRequest) ProtoMessage() {}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) ProtoReflect() protoreflect.Message {
|
||||||
|
mi := &file_api_v2_user_service_proto_msgTypes[3]
|
||||||
|
if protoimpl.UnsafeEnabled && x != nil {
|
||||||
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
|
if ms.LoadMessageInfo() == nil {
|
||||||
|
ms.StoreMessageInfo(mi)
|
||||||
|
}
|
||||||
|
return ms
|
||||||
|
}
|
||||||
|
return mi.MessageOf(x)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deprecated: Use UpdateUserRequest.ProtoReflect.Descriptor instead.
|
||||||
|
func (*UpdateUserRequest) Descriptor() ([]byte, []int) {
|
||||||
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{3}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) GetUsername() string {
|
||||||
|
if x != nil {
|
||||||
|
return x.Username
|
||||||
|
}
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) GetUser() *User {
|
||||||
|
if x != nil {
|
||||||
|
return x.User
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserRequest) GetUpdateMask() *fieldmaskpb.FieldMask {
|
||||||
|
if x != nil {
|
||||||
|
return x.UpdateMask
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type UpdateUserResponse struct {
|
||||||
|
state protoimpl.MessageState
|
||||||
|
sizeCache protoimpl.SizeCache
|
||||||
|
unknownFields protoimpl.UnknownFields
|
||||||
|
|
||||||
|
User *User `protobuf:"bytes,1,opt,name=user,proto3" json:"user,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserResponse) Reset() {
|
||||||
|
*x = UpdateUserResponse{}
|
||||||
|
if protoimpl.UnsafeEnabled {
|
||||||
|
mi := &file_api_v2_user_service_proto_msgTypes[4]
|
||||||
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
|
ms.StoreMessageInfo(mi)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserResponse) String() string {
|
||||||
|
return protoimpl.X.MessageStringOf(x)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*UpdateUserResponse) ProtoMessage() {}
|
||||||
|
|
||||||
|
func (x *UpdateUserResponse) ProtoReflect() protoreflect.Message {
|
||||||
|
mi := &file_api_v2_user_service_proto_msgTypes[4]
|
||||||
|
if protoimpl.UnsafeEnabled && x != nil {
|
||||||
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
|
if ms.LoadMessageInfo() == nil {
|
||||||
|
ms.StoreMessageInfo(mi)
|
||||||
|
}
|
||||||
|
return ms
|
||||||
|
}
|
||||||
|
return mi.MessageOf(x)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deprecated: Use UpdateUserResponse.ProtoReflect.Descriptor instead.
|
||||||
|
func (*UpdateUserResponse) Descriptor() ([]byte, []int) {
|
||||||
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{4}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *UpdateUserResponse) GetUser() *User {
|
||||||
|
if x != nil {
|
||||||
|
return x.User
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
type UserSetting struct {
|
type UserSetting struct {
|
||||||
state protoimpl.MessageState
|
state protoimpl.MessageState
|
||||||
sizeCache protoimpl.SizeCache
|
sizeCache protoimpl.SizeCache
|
||||||
@ -361,7 +482,7 @@ type UserSetting struct {
|
|||||||
func (x *UserSetting) Reset() {
|
func (x *UserSetting) Reset() {
|
||||||
*x = UserSetting{}
|
*x = UserSetting{}
|
||||||
if protoimpl.UnsafeEnabled {
|
if protoimpl.UnsafeEnabled {
|
||||||
mi := &file_api_v2_user_service_proto_msgTypes[3]
|
mi := &file_api_v2_user_service_proto_msgTypes[5]
|
||||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
ms.StoreMessageInfo(mi)
|
ms.StoreMessageInfo(mi)
|
||||||
}
|
}
|
||||||
@ -374,7 +495,7 @@ func (x *UserSetting) String() string {
|
|||||||
func (*UserSetting) ProtoMessage() {}
|
func (*UserSetting) ProtoMessage() {}
|
||||||
|
|
||||||
func (x *UserSetting) ProtoReflect() protoreflect.Message {
|
func (x *UserSetting) ProtoReflect() protoreflect.Message {
|
||||||
mi := &file_api_v2_user_service_proto_msgTypes[3]
|
mi := &file_api_v2_user_service_proto_msgTypes[5]
|
||||||
if protoimpl.UnsafeEnabled && x != nil {
|
if protoimpl.UnsafeEnabled && x != nil {
|
||||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
if ms.LoadMessageInfo() == nil {
|
if ms.LoadMessageInfo() == nil {
|
||||||
@ -387,7 +508,7 @@ func (x *UserSetting) ProtoReflect() protoreflect.Message {
|
|||||||
|
|
||||||
// Deprecated: Use UserSetting.ProtoReflect.Descriptor instead.
|
// Deprecated: Use UserSetting.ProtoReflect.Descriptor instead.
|
||||||
func (*UserSetting) Descriptor() ([]byte, []int) {
|
func (*UserSetting) Descriptor() ([]byte, []int) {
|
||||||
return file_api_v2_user_service_proto_rawDescGZIP(), []int{3}
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{5}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (x *UserSetting) GetUserId() int32 {
|
func (x *UserSetting) GetUserId() int32 {
|
||||||
@ -426,7 +547,7 @@ type UserSettingValue struct {
|
|||||||
func (x *UserSettingValue) Reset() {
|
func (x *UserSettingValue) Reset() {
|
||||||
*x = UserSettingValue{}
|
*x = UserSettingValue{}
|
||||||
if protoimpl.UnsafeEnabled {
|
if protoimpl.UnsafeEnabled {
|
||||||
mi := &file_api_v2_user_service_proto_msgTypes[4]
|
mi := &file_api_v2_user_service_proto_msgTypes[6]
|
||||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
ms.StoreMessageInfo(mi)
|
ms.StoreMessageInfo(mi)
|
||||||
}
|
}
|
||||||
@ -439,7 +560,7 @@ func (x *UserSettingValue) String() string {
|
|||||||
func (*UserSettingValue) ProtoMessage() {}
|
func (*UserSettingValue) ProtoMessage() {}
|
||||||
|
|
||||||
func (x *UserSettingValue) ProtoReflect() protoreflect.Message {
|
func (x *UserSettingValue) ProtoReflect() protoreflect.Message {
|
||||||
mi := &file_api_v2_user_service_proto_msgTypes[4]
|
mi := &file_api_v2_user_service_proto_msgTypes[6]
|
||||||
if protoimpl.UnsafeEnabled && x != nil {
|
if protoimpl.UnsafeEnabled && x != nil {
|
||||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||||
if ms.LoadMessageInfo() == nil {
|
if ms.LoadMessageInfo() == nil {
|
||||||
@ -452,7 +573,7 @@ func (x *UserSettingValue) ProtoReflect() protoreflect.Message {
|
|||||||
|
|
||||||
// Deprecated: Use UserSettingValue.ProtoReflect.Descriptor instead.
|
// Deprecated: Use UserSettingValue.ProtoReflect.Descriptor instead.
|
||||||
func (*UserSettingValue) Descriptor() ([]byte, []int) {
|
func (*UserSettingValue) Descriptor() ([]byte, []int) {
|
||||||
return file_api_v2_user_service_proto_rawDescGZIP(), []int{4}
|
return file_api_v2_user_service_proto_rawDescGZIP(), []int{6}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *UserSettingValue) GetValue() isUserSettingValue_Value {
|
func (m *UserSettingValue) GetValue() isUserSettingValue_Value {
|
||||||
@ -505,29 +626,59 @@ var file_api_v2_user_service_proto_rawDesc = []byte{
|
|||||||
0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x61, 0x6e, 0x6e, 0x6f, 0x74, 0x61, 0x74, 0x69, 0x6f, 0x6e,
|
0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x61, 0x6e, 0x6e, 0x6f, 0x74, 0x61, 0x74, 0x69, 0x6f, 0x6e,
|
||||||
0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x1a, 0x17, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f,
|
0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x1a, 0x17, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f,
|
||||||
0x61, 0x70, 0x69, 0x2f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f,
|
0x61, 0x70, 0x69, 0x2f, 0x63, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f,
|
||||||
0x22, 0xba, 0x02, 0x0a, 0x04, 0x55, 0x73, 0x65, 0x72, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18,
|
0x1a, 0x1f, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x66, 0x69, 0x65,
|
||||||
0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, 0x12, 0x36, 0x0a, 0x0a, 0x72, 0x6f, 0x77,
|
0x6c, 0x64, 0x5f, 0x62, 0x65, 0x68, 0x61, 0x76, 0x69, 0x6f, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74,
|
||||||
0x5f, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x17, 0x2e,
|
0x6f, 0x1a, 0x20, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62,
|
||||||
0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x52, 0x6f, 0x77,
|
0x75, 0x66, 0x2f, 0x66, 0x69, 0x65, 0x6c, 0x64, 0x5f, 0x6d, 0x61, 0x73, 0x6b, 0x2e, 0x70, 0x72,
|
||||||
0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x52, 0x09, 0x72, 0x6f, 0x77, 0x53, 0x74, 0x61, 0x74, 0x75,
|
0x6f, 0x74, 0x6f, 0x1a, 0x1f, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x70, 0x72, 0x6f, 0x74,
|
||||||
0x73, 0x12, 0x1d, 0x0a, 0x0a, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, 0x5f, 0x74, 0x73, 0x18,
|
0x6f, 0x62, 0x75, 0x66, 0x2f, 0x74, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x2e, 0x70,
|
||||||
0x03, 0x20, 0x01, 0x28, 0x03, 0x52, 0x09, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x64, 0x54, 0x73,
|
0x72, 0x6f, 0x74, 0x6f, 0x22, 0xd9, 0x03, 0x0a, 0x04, 0x55, 0x73, 0x65, 0x72, 0x12, 0x0e, 0x0a,
|
||||||
0x12, 0x1d, 0x0a, 0x0a, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x64, 0x5f, 0x74, 0x73, 0x18, 0x04,
|
0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x02, 0x69, 0x64, 0x12, 0x36, 0x0a,
|
||||||
0x20, 0x01, 0x28, 0x03, 0x52, 0x09, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x64, 0x54, 0x73, 0x12,
|
0x0a, 0x72, 0x6f, 0x77, 0x5f, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28,
|
||||||
|
0x0e, 0x32, 0x17, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32,
|
||||||
|
0x2e, 0x52, 0x6f, 0x77, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x52, 0x09, 0x72, 0x6f, 0x77, 0x53,
|
||||||
|
0x74, 0x61, 0x74, 0x75, 0x73, 0x12, 0x3b, 0x0a, 0x0b, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x5f,
|
||||||
|
0x74, 0x69, 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x67, 0x6f, 0x6f,
|
||||||
|
0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x54, 0x69, 0x6d,
|
||||||
|
0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x52, 0x0a, 0x63, 0x72, 0x65, 0x61, 0x74, 0x65, 0x54, 0x69,
|
||||||
|
0x6d, 0x65, 0x12, 0x3b, 0x0a, 0x0b, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x5f, 0x74, 0x69, 0x6d,
|
||||||
|
0x65, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65,
|
||||||
|
0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74,
|
||||||
|
0x61, 0x6d, 0x70, 0x52, 0x0a, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x54, 0x69, 0x6d, 0x65, 0x12,
|
||||||
0x1a, 0x0a, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x05, 0x20, 0x01, 0x28,
|
0x1a, 0x0a, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x05, 0x20, 0x01, 0x28,
|
||||||
0x09, 0x52, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x26, 0x0a, 0x04, 0x72,
|
0x09, 0x52, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x2b, 0x0a, 0x04, 0x72,
|
||||||
0x6f, 0x6c, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x12, 0x2e, 0x6d, 0x65, 0x6d, 0x6f,
|
0x6f, 0x6c, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x17, 0x2e, 0x6d, 0x65, 0x6d, 0x6f,
|
||||||
0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x52, 0x6f, 0x6c, 0x65, 0x52, 0x04, 0x72,
|
0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x55, 0x73, 0x65, 0x72, 0x2e, 0x52, 0x6f,
|
||||||
0x6f, 0x6c, 0x65, 0x12, 0x14, 0x0a, 0x05, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x18, 0x07, 0x20, 0x01,
|
0x6c, 0x65, 0x52, 0x04, 0x72, 0x6f, 0x6c, 0x65, 0x12, 0x14, 0x0a, 0x05, 0x65, 0x6d, 0x61, 0x69,
|
||||||
0x28, 0x09, 0x52, 0x05, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x12, 0x1a, 0x0a, 0x08, 0x6e, 0x69, 0x63,
|
0x6c, 0x18, 0x07, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x12, 0x1a,
|
||||||
0x6b, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x08, 0x20, 0x01, 0x28, 0x09, 0x52, 0x08, 0x6e, 0x69, 0x63,
|
0x0a, 0x08, 0x6e, 0x69, 0x63, 0x6b, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x08, 0x20, 0x01, 0x28, 0x09,
|
||||||
0x6b, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x17, 0x0a, 0x07, 0x6f, 0x70, 0x65, 0x6e, 0x5f, 0x69, 0x64,
|
0x52, 0x08, 0x6e, 0x69, 0x63, 0x6b, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x17, 0x0a, 0x07, 0x6f, 0x70,
|
||||||
0x18, 0x09, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x6f, 0x70, 0x65, 0x6e, 0x49, 0x64, 0x12, 0x1d,
|
0x65, 0x6e, 0x5f, 0x69, 0x64, 0x18, 0x09, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x6f, 0x70, 0x65,
|
||||||
0x0a, 0x0a, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x0a, 0x20, 0x01,
|
0x6e, 0x49, 0x64, 0x12, 0x1d, 0x0a, 0x0a, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x5f, 0x75, 0x72,
|
||||||
0x28, 0x09, 0x52, 0x09, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x55, 0x72, 0x6c, 0x22, 0x24, 0x0a,
|
0x6c, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x09, 0x52, 0x09, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x55,
|
||||||
0x0e, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12,
|
0x72, 0x6c, 0x12, 0x1f, 0x0a, 0x08, 0x70, 0x61, 0x73, 0x73, 0x77, 0x6f, 0x72, 0x64, 0x18, 0x0b,
|
||||||
0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e,
|
0x20, 0x01, 0x28, 0x09, 0x42, 0x03, 0xe0, 0x41, 0x04, 0x52, 0x08, 0x70, 0x61, 0x73, 0x73, 0x77,
|
||||||
0x61, 0x6d, 0x65, 0x22, 0x39, 0x0a, 0x0f, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65,
|
0x6f, 0x72, 0x64, 0x22, 0x3b, 0x0a, 0x04, 0x52, 0x6f, 0x6c, 0x65, 0x12, 0x14, 0x0a, 0x10, 0x52,
|
||||||
|
0x4f, 0x4c, 0x45, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10,
|
||||||
|
0x00, 0x12, 0x08, 0x0a, 0x04, 0x48, 0x4f, 0x53, 0x54, 0x10, 0x01, 0x12, 0x09, 0x0a, 0x05, 0x41,
|
||||||
|
0x44, 0x4d, 0x49, 0x4e, 0x10, 0x02, 0x12, 0x08, 0x0a, 0x04, 0x55, 0x53, 0x45, 0x52, 0x10, 0x03,
|
||||||
|
0x22, 0x2c, 0x0a, 0x0e, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65,
|
||||||
|
0x73, 0x74, 0x12, 0x1a, 0x0a, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01,
|
||||||
|
0x20, 0x01, 0x28, 0x09, 0x52, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x22, 0x39,
|
||||||
|
0x0a, 0x0f, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73,
|
||||||
|
0x65, 0x12, 0x26, 0x0a, 0x04, 0x75, 0x73, 0x65, 0x72, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32,
|
||||||
|
0x12, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x55,
|
||||||
|
0x73, 0x65, 0x72, 0x52, 0x04, 0x75, 0x73, 0x65, 0x72, 0x22, 0x94, 0x01, 0x0a, 0x11, 0x55, 0x70,
|
||||||
|
0x64, 0x61, 0x74, 0x65, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12,
|
||||||
|
0x1a, 0x0a, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28,
|
||||||
|
0x09, 0x52, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x12, 0x26, 0x0a, 0x04, 0x75,
|
||||||
|
0x73, 0x65, 0x72, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x6d, 0x65, 0x6d, 0x6f,
|
||||||
|
0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x55, 0x73, 0x65, 0x72, 0x52, 0x04, 0x75,
|
||||||
|
0x73, 0x65, 0x72, 0x12, 0x3b, 0x0a, 0x0b, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x5f, 0x6d, 0x61,
|
||||||
|
0x73, 0x6b, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c,
|
||||||
|
0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x46, 0x69, 0x65, 0x6c, 0x64,
|
||||||
|
0x4d, 0x61, 0x73, 0x6b, 0x52, 0x0a, 0x75, 0x70, 0x64, 0x61, 0x74, 0x65, 0x4d, 0x61, 0x73, 0x6b,
|
||||||
|
0x22, 0x3c, 0x0a, 0x12, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65,
|
||||||
0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x26, 0x0a, 0x04, 0x75, 0x73, 0x65, 0x72, 0x18, 0x01,
|
0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x26, 0x0a, 0x04, 0x75, 0x73, 0x65, 0x72, 0x18, 0x01,
|
||||||
0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69,
|
0x20, 0x01, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69,
|
||||||
0x2e, 0x76, 0x32, 0x2e, 0x55, 0x73, 0x65, 0x72, 0x52, 0x04, 0x75, 0x73, 0x65, 0x72, 0x22, 0xf0,
|
0x2e, 0x76, 0x32, 0x2e, 0x55, 0x73, 0x65, 0x72, 0x52, 0x04, 0x75, 0x73, 0x65, 0x72, 0x22, 0xf0,
|
||||||
@ -554,30 +705,35 @@ var file_api_v2_user_service_proto_rawDesc = []byte{
|
|||||||
0x02, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x18, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70,
|
0x02, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x18, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70,
|
||||||
0x69, 0x2e, 0x76, 0x32, 0x2e, 0x56, 0x69, 0x73, 0x69, 0x62, 0x69, 0x6c, 0x69, 0x74, 0x79, 0x48,
|
0x69, 0x2e, 0x76, 0x32, 0x2e, 0x56, 0x69, 0x73, 0x69, 0x62, 0x69, 0x6c, 0x69, 0x74, 0x79, 0x48,
|
||||||
0x00, 0x52, 0x0f, 0x76, 0x69, 0x73, 0x69, 0x62, 0x69, 0x6c, 0x69, 0x74, 0x79, 0x56, 0x61, 0x6c,
|
0x00, 0x52, 0x0f, 0x76, 0x69, 0x73, 0x69, 0x62, 0x69, 0x6c, 0x69, 0x74, 0x79, 0x56, 0x61, 0x6c,
|
||||||
0x75, 0x65, 0x42, 0x07, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x2a, 0x3b, 0x0a, 0x04, 0x52,
|
0x75, 0x65, 0x42, 0x07, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x32, 0x80, 0x02, 0x0a, 0x0b,
|
||||||
0x6f, 0x6c, 0x65, 0x12, 0x14, 0x0a, 0x10, 0x52, 0x4f, 0x4c, 0x45, 0x5f, 0x55, 0x4e, 0x53, 0x50,
|
0x55, 0x73, 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x73, 0x0a, 0x07, 0x47,
|
||||||
0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x08, 0x0a, 0x04, 0x48, 0x4f, 0x53,
|
0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x12, 0x1c, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61,
|
||||||
0x54, 0x10, 0x01, 0x12, 0x09, 0x0a, 0x05, 0x41, 0x44, 0x4d, 0x49, 0x4e, 0x10, 0x02, 0x12, 0x08,
|
0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71,
|
||||||
0x0a, 0x04, 0x55, 0x53, 0x45, 0x52, 0x10, 0x03, 0x32, 0x7a, 0x0a, 0x0b, 0x55, 0x73, 0x65, 0x72,
|
0x75, 0x65, 0x73, 0x74, 0x1a, 0x1d, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69,
|
||||||
0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x6b, 0x0a, 0x07, 0x47, 0x65, 0x74, 0x55, 0x73,
|
0x2e, 0x76, 0x32, 0x2e, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x73, 0x70, 0x6f,
|
||||||
0x65, 0x72, 0x12, 0x1c, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76,
|
0x6e, 0x73, 0x65, 0x22, 0x2b, 0xda, 0x41, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65,
|
||||||
0x32, 0x2e, 0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74,
|
0x82, 0xd3, 0xe4, 0x93, 0x02, 0x1a, 0x12, 0x18, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x76, 0x32, 0x2f,
|
||||||
0x1a, 0x1d, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e,
|
0x75, 0x73, 0x65, 0x72, 0x73, 0x2f, 0x7b, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x7d,
|
||||||
0x47, 0x65, 0x74, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22,
|
0x12, 0x7c, 0x0a, 0x0a, 0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x55, 0x73, 0x65, 0x72, 0x12, 0x1f,
|
||||||
0x23, 0xda, 0x41, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x82, 0xd3, 0xe4, 0x93, 0x02, 0x16, 0x12, 0x14,
|
0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x55, 0x70,
|
||||||
0x2f, 0x61, 0x70, 0x69, 0x2f, 0x76, 0x32, 0x2f, 0x75, 0x73, 0x65, 0x72, 0x73, 0x2f, 0x7b, 0x6e,
|
0x64, 0x61, 0x74, 0x65, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a,
|
||||||
0x61, 0x6d, 0x65, 0x7d, 0x42, 0xa8, 0x01, 0x0a, 0x10, 0x63, 0x6f, 0x6d, 0x2e, 0x6d, 0x65, 0x6d,
|
0x20, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x2e, 0x55,
|
||||||
0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x76, 0x32, 0x42, 0x10, 0x55, 0x73, 0x65, 0x72, 0x53,
|
0x70, 0x64, 0x61, 0x74, 0x65, 0x55, 0x73, 0x65, 0x72, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73,
|
||||||
0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x50, 0x72, 0x6f, 0x74, 0x6f, 0x50, 0x01, 0x5a, 0x30, 0x67,
|
0x65, 0x22, 0x2b, 0xda, 0x41, 0x08, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x82, 0xd3,
|
||||||
0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x75, 0x73, 0x65, 0x6d, 0x65, 0x6d,
|
0xe4, 0x93, 0x02, 0x1a, 0x32, 0x18, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x76, 0x32, 0x2f, 0x75, 0x73,
|
||||||
0x6f, 0x73, 0x2f, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x67,
|
0x65, 0x72, 0x73, 0x2f, 0x7b, 0x75, 0x73, 0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0x7d, 0x42, 0xa8,
|
||||||
0x65, 0x6e, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x76, 0x32, 0x3b, 0x61, 0x70, 0x69, 0x76, 0x32, 0xa2,
|
0x01, 0x0a, 0x10, 0x63, 0x6f, 0x6d, 0x2e, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x61, 0x70, 0x69,
|
||||||
0x02, 0x03, 0x4d, 0x41, 0x58, 0xaa, 0x02, 0x0c, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x41, 0x70,
|
0x2e, 0x76, 0x32, 0x42, 0x10, 0x55, 0x73, 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65,
|
||||||
0x69, 0x2e, 0x56, 0x32, 0xca, 0x02, 0x0c, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x5c, 0x41, 0x70, 0x69,
|
0x50, 0x72, 0x6f, 0x74, 0x6f, 0x50, 0x01, 0x5a, 0x30, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e,
|
||||||
0x5c, 0x56, 0x32, 0xe2, 0x02, 0x18, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x5c, 0x41, 0x70, 0x69, 0x5c,
|
0x63, 0x6f, 0x6d, 0x2f, 0x75, 0x73, 0x65, 0x6d, 0x65, 0x6d, 0x6f, 0x73, 0x2f, 0x6d, 0x65, 0x6d,
|
||||||
0x56, 0x32, 0x5c, 0x47, 0x50, 0x42, 0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0xea, 0x02,
|
0x6f, 0x73, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x67, 0x65, 0x6e, 0x2f, 0x61, 0x70, 0x69,
|
||||||
0x0e, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x3a, 0x3a, 0x41, 0x70, 0x69, 0x3a, 0x3a, 0x56, 0x32, 0x62,
|
0x2f, 0x76, 0x32, 0x3b, 0x61, 0x70, 0x69, 0x76, 0x32, 0xa2, 0x02, 0x03, 0x4d, 0x41, 0x58, 0xaa,
|
||||||
0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
|
0x02, 0x0c, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x2e, 0x41, 0x70, 0x69, 0x2e, 0x56, 0x32, 0xca, 0x02,
|
||||||
|
0x0c, 0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x5c, 0x41, 0x70, 0x69, 0x5c, 0x56, 0x32, 0xe2, 0x02, 0x18,
|
||||||
|
0x4d, 0x65, 0x6d, 0x6f, 0x73, 0x5c, 0x41, 0x70, 0x69, 0x5c, 0x56, 0x32, 0x5c, 0x47, 0x50, 0x42,
|
||||||
|
0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0xea, 0x02, 0x0e, 0x4d, 0x65, 0x6d, 0x6f, 0x73,
|
||||||
|
0x3a, 0x3a, 0x41, 0x70, 0x69, 0x3a, 0x3a, 0x56, 0x32, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f,
|
||||||
|
0x33,
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -593,32 +749,43 @@ func file_api_v2_user_service_proto_rawDescGZIP() []byte {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var file_api_v2_user_service_proto_enumTypes = make([]protoimpl.EnumInfo, 2)
|
var file_api_v2_user_service_proto_enumTypes = make([]protoimpl.EnumInfo, 2)
|
||||||
var file_api_v2_user_service_proto_msgTypes = make([]protoimpl.MessageInfo, 5)
|
var file_api_v2_user_service_proto_msgTypes = make([]protoimpl.MessageInfo, 7)
|
||||||
var file_api_v2_user_service_proto_goTypes = []interface{}{
|
var file_api_v2_user_service_proto_goTypes = []interface{}{
|
||||||
(Role)(0), // 0: memos.api.v2.Role
|
(User_Role)(0), // 0: memos.api.v2.User.Role
|
||||||
(UserSetting_Key)(0), // 1: memos.api.v2.UserSetting.Key
|
(UserSetting_Key)(0), // 1: memos.api.v2.UserSetting.Key
|
||||||
(*User)(nil), // 2: memos.api.v2.User
|
(*User)(nil), // 2: memos.api.v2.User
|
||||||
(*GetUserRequest)(nil), // 3: memos.api.v2.GetUserRequest
|
(*GetUserRequest)(nil), // 3: memos.api.v2.GetUserRequest
|
||||||
(*GetUserResponse)(nil), // 4: memos.api.v2.GetUserResponse
|
(*GetUserResponse)(nil), // 4: memos.api.v2.GetUserResponse
|
||||||
(*UserSetting)(nil), // 5: memos.api.v2.UserSetting
|
(*UpdateUserRequest)(nil), // 5: memos.api.v2.UpdateUserRequest
|
||||||
(*UserSettingValue)(nil), // 6: memos.api.v2.UserSettingValue
|
(*UpdateUserResponse)(nil), // 6: memos.api.v2.UpdateUserResponse
|
||||||
(RowStatus)(0), // 7: memos.api.v2.RowStatus
|
(*UserSetting)(nil), // 7: memos.api.v2.UserSetting
|
||||||
(Visibility)(0), // 8: memos.api.v2.Visibility
|
(*UserSettingValue)(nil), // 8: memos.api.v2.UserSettingValue
|
||||||
|
(RowStatus)(0), // 9: memos.api.v2.RowStatus
|
||||||
|
(*timestamppb.Timestamp)(nil), // 10: google.protobuf.Timestamp
|
||||||
|
(*fieldmaskpb.FieldMask)(nil), // 11: google.protobuf.FieldMask
|
||||||
|
(Visibility)(0), // 12: memos.api.v2.Visibility
|
||||||
}
|
}
|
||||||
var file_api_v2_user_service_proto_depIdxs = []int32{
|
var file_api_v2_user_service_proto_depIdxs = []int32{
|
||||||
7, // 0: memos.api.v2.User.row_status:type_name -> memos.api.v2.RowStatus
|
9, // 0: memos.api.v2.User.row_status:type_name -> memos.api.v2.RowStatus
|
||||||
0, // 1: memos.api.v2.User.role:type_name -> memos.api.v2.Role
|
10, // 1: memos.api.v2.User.create_time:type_name -> google.protobuf.Timestamp
|
||||||
2, // 2: memos.api.v2.GetUserResponse.user:type_name -> memos.api.v2.User
|
10, // 2: memos.api.v2.User.update_time:type_name -> google.protobuf.Timestamp
|
||||||
1, // 3: memos.api.v2.UserSetting.key:type_name -> memos.api.v2.UserSetting.Key
|
0, // 3: memos.api.v2.User.role:type_name -> memos.api.v2.User.Role
|
||||||
6, // 4: memos.api.v2.UserSetting.value:type_name -> memos.api.v2.UserSettingValue
|
2, // 4: memos.api.v2.GetUserResponse.user:type_name -> memos.api.v2.User
|
||||||
8, // 5: memos.api.v2.UserSettingValue.visibility_value:type_name -> memos.api.v2.Visibility
|
2, // 5: memos.api.v2.UpdateUserRequest.user:type_name -> memos.api.v2.User
|
||||||
3, // 6: memos.api.v2.UserService.GetUser:input_type -> memos.api.v2.GetUserRequest
|
11, // 6: memos.api.v2.UpdateUserRequest.update_mask:type_name -> google.protobuf.FieldMask
|
||||||
4, // 7: memos.api.v2.UserService.GetUser:output_type -> memos.api.v2.GetUserResponse
|
2, // 7: memos.api.v2.UpdateUserResponse.user:type_name -> memos.api.v2.User
|
||||||
7, // [7:8] is the sub-list for method output_type
|
1, // 8: memos.api.v2.UserSetting.key:type_name -> memos.api.v2.UserSetting.Key
|
||||||
6, // [6:7] is the sub-list for method input_type
|
8, // 9: memos.api.v2.UserSetting.value:type_name -> memos.api.v2.UserSettingValue
|
||||||
6, // [6:6] is the sub-list for extension type_name
|
12, // 10: memos.api.v2.UserSettingValue.visibility_value:type_name -> memos.api.v2.Visibility
|
||||||
6, // [6:6] is the sub-list for extension extendee
|
3, // 11: memos.api.v2.UserService.GetUser:input_type -> memos.api.v2.GetUserRequest
|
||||||
0, // [0:6] is the sub-list for field type_name
|
5, // 12: memos.api.v2.UserService.UpdateUser:input_type -> memos.api.v2.UpdateUserRequest
|
||||||
|
4, // 13: memos.api.v2.UserService.GetUser:output_type -> memos.api.v2.GetUserResponse
|
||||||
|
6, // 14: memos.api.v2.UserService.UpdateUser:output_type -> memos.api.v2.UpdateUserResponse
|
||||||
|
13, // [13:15] is the sub-list for method output_type
|
||||||
|
11, // [11:13] is the sub-list for method input_type
|
||||||
|
11, // [11:11] is the sub-list for extension type_name
|
||||||
|
11, // [11:11] is the sub-list for extension extendee
|
||||||
|
0, // [0:11] is the sub-list for field type_name
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() { file_api_v2_user_service_proto_init() }
|
func init() { file_api_v2_user_service_proto_init() }
|
||||||
@ -666,7 +833,7 @@ func file_api_v2_user_service_proto_init() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
file_api_v2_user_service_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} {
|
file_api_v2_user_service_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} {
|
||||||
switch v := v.(*UserSetting); i {
|
switch v := v.(*UpdateUserRequest); i {
|
||||||
case 0:
|
case 0:
|
||||||
return &v.state
|
return &v.state
|
||||||
case 1:
|
case 1:
|
||||||
@ -678,6 +845,30 @@ func file_api_v2_user_service_proto_init() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
file_api_v2_user_service_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} {
|
file_api_v2_user_service_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} {
|
||||||
|
switch v := v.(*UpdateUserResponse); i {
|
||||||
|
case 0:
|
||||||
|
return &v.state
|
||||||
|
case 1:
|
||||||
|
return &v.sizeCache
|
||||||
|
case 2:
|
||||||
|
return &v.unknownFields
|
||||||
|
default:
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
file_api_v2_user_service_proto_msgTypes[5].Exporter = func(v interface{}, i int) interface{} {
|
||||||
|
switch v := v.(*UserSetting); i {
|
||||||
|
case 0:
|
||||||
|
return &v.state
|
||||||
|
case 1:
|
||||||
|
return &v.sizeCache
|
||||||
|
case 2:
|
||||||
|
return &v.unknownFields
|
||||||
|
default:
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
file_api_v2_user_service_proto_msgTypes[6].Exporter = func(v interface{}, i int) interface{} {
|
||||||
switch v := v.(*UserSettingValue); i {
|
switch v := v.(*UserSettingValue); i {
|
||||||
case 0:
|
case 0:
|
||||||
return &v.state
|
return &v.state
|
||||||
@ -690,7 +881,7 @@ func file_api_v2_user_service_proto_init() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
file_api_v2_user_service_proto_msgTypes[4].OneofWrappers = []interface{}{
|
file_api_v2_user_service_proto_msgTypes[6].OneofWrappers = []interface{}{
|
||||||
(*UserSettingValue_StringValue)(nil),
|
(*UserSettingValue_StringValue)(nil),
|
||||||
(*UserSettingValue_VisibilityValue)(nil),
|
(*UserSettingValue_VisibilityValue)(nil),
|
||||||
}
|
}
|
||||||
@ -700,7 +891,7 @@ func file_api_v2_user_service_proto_init() {
|
|||||||
GoPackagePath: reflect.TypeOf(x{}).PkgPath(),
|
GoPackagePath: reflect.TypeOf(x{}).PkgPath(),
|
||||||
RawDescriptor: file_api_v2_user_service_proto_rawDesc,
|
RawDescriptor: file_api_v2_user_service_proto_rawDesc,
|
||||||
NumEnums: 2,
|
NumEnums: 2,
|
||||||
NumMessages: 5,
|
NumMessages: 7,
|
||||||
NumExtensions: 0,
|
NumExtensions: 0,
|
||||||
NumServices: 1,
|
NumServices: 1,
|
||||||
},
|
},
|
||||||
|
@ -42,14 +42,14 @@ func request_UserService_GetUser_0(ctx context.Context, marshaler runtime.Marsha
|
|||||||
_ = err
|
_ = err
|
||||||
)
|
)
|
||||||
|
|
||||||
val, ok = pathParams["name"]
|
val, ok = pathParams["username"]
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name")
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "username")
|
||||||
}
|
}
|
||||||
|
|
||||||
protoReq.Name, err = runtime.String(val)
|
protoReq.Username, err = runtime.String(val)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err)
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "username", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
msg, err := client.GetUser(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD))
|
msg, err := client.GetUser(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD))
|
||||||
@ -68,14 +68,14 @@ func local_request_UserService_GetUser_0(ctx context.Context, marshaler runtime.
|
|||||||
_ = err
|
_ = err
|
||||||
)
|
)
|
||||||
|
|
||||||
val, ok = pathParams["name"]
|
val, ok = pathParams["username"]
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name")
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "username")
|
||||||
}
|
}
|
||||||
|
|
||||||
protoReq.Name, err = runtime.String(val)
|
protoReq.Username, err = runtime.String(val)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err)
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "username", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
msg, err := server.GetUser(ctx, &protoReq)
|
msg, err := server.GetUser(ctx, &protoReq)
|
||||||
@ -83,6 +83,76 @@ func local_request_UserService_GetUser_0(ctx context.Context, marshaler runtime.
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
filter_UserService_UpdateUser_0 = &utilities.DoubleArray{Encoding: map[string]int{"username": 0}, Base: []int{1, 2, 0, 0}, Check: []int{0, 1, 2, 2}}
|
||||||
|
)
|
||||||
|
|
||||||
|
func request_UserService_UpdateUser_0(ctx context.Context, marshaler runtime.Marshaler, client UserServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) {
|
||||||
|
var protoReq UpdateUserRequest
|
||||||
|
var metadata runtime.ServerMetadata
|
||||||
|
|
||||||
|
var (
|
||||||
|
val string
|
||||||
|
ok bool
|
||||||
|
err error
|
||||||
|
_ = err
|
||||||
|
)
|
||||||
|
|
||||||
|
val, ok = pathParams["username"]
|
||||||
|
if !ok {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "username")
|
||||||
|
}
|
||||||
|
|
||||||
|
protoReq.Username, err = runtime.String(val)
|
||||||
|
if err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "username", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := req.ParseForm(); err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err)
|
||||||
|
}
|
||||||
|
if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_UserService_UpdateUser_0); err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
msg, err := client.UpdateUser(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD))
|
||||||
|
return msg, metadata, err
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func local_request_UserService_UpdateUser_0(ctx context.Context, marshaler runtime.Marshaler, server UserServiceServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) {
|
||||||
|
var protoReq UpdateUserRequest
|
||||||
|
var metadata runtime.ServerMetadata
|
||||||
|
|
||||||
|
var (
|
||||||
|
val string
|
||||||
|
ok bool
|
||||||
|
err error
|
||||||
|
_ = err
|
||||||
|
)
|
||||||
|
|
||||||
|
val, ok = pathParams["username"]
|
||||||
|
if !ok {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "username")
|
||||||
|
}
|
||||||
|
|
||||||
|
protoReq.Username, err = runtime.String(val)
|
||||||
|
if err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "username", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := req.ParseForm(); err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err)
|
||||||
|
}
|
||||||
|
if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_UserService_UpdateUser_0); err != nil {
|
||||||
|
return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
msg, err := server.UpdateUser(ctx, &protoReq)
|
||||||
|
return msg, metadata, err
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
// RegisterUserServiceHandlerServer registers the http handlers for service UserService to "mux".
|
// RegisterUserServiceHandlerServer registers the http handlers for service UserService to "mux".
|
||||||
// UnaryRPC :call UserServiceServer directly.
|
// UnaryRPC :call UserServiceServer directly.
|
||||||
// StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906.
|
// StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906.
|
||||||
@ -97,7 +167,7 @@ func RegisterUserServiceHandlerServer(ctx context.Context, mux *runtime.ServeMux
|
|||||||
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
||||||
var err error
|
var err error
|
||||||
var annotatedContext context.Context
|
var annotatedContext context.Context
|
||||||
annotatedContext, err = runtime.AnnotateIncomingContext(ctx, mux, req, "/memos.api.v2.UserService/GetUser", runtime.WithHTTPPathPattern("/api/v2/users/{name}"))
|
annotatedContext, err = runtime.AnnotateIncomingContext(ctx, mux, req, "/memos.api.v2.UserService/GetUser", runtime.WithHTTPPathPattern("/api/v2/users/{username}"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
||||||
return
|
return
|
||||||
@ -114,6 +184,31 @@ func RegisterUserServiceHandlerServer(ctx context.Context, mux *runtime.ServeMux
|
|||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
mux.Handle("PATCH", pattern_UserService_UpdateUser_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) {
|
||||||
|
ctx, cancel := context.WithCancel(req.Context())
|
||||||
|
defer cancel()
|
||||||
|
var stream runtime.ServerTransportStream
|
||||||
|
ctx = grpc.NewContextWithServerTransportStream(ctx, &stream)
|
||||||
|
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
||||||
|
var err error
|
||||||
|
var annotatedContext context.Context
|
||||||
|
annotatedContext, err = runtime.AnnotateIncomingContext(ctx, mux, req, "/memos.api.v2.UserService/UpdateUser", runtime.WithHTTPPathPattern("/api/v2/users/{username}"))
|
||||||
|
if err != nil {
|
||||||
|
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
resp, md, err := local_request_UserService_UpdateUser_0(annotatedContext, inboundMarshaler, server, req, pathParams)
|
||||||
|
md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer())
|
||||||
|
annotatedContext = runtime.NewServerMetadataContext(annotatedContext, md)
|
||||||
|
if err != nil {
|
||||||
|
runtime.HTTPError(annotatedContext, mux, outboundMarshaler, w, req, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
forward_UserService_UpdateUser_0(annotatedContext, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...)
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -161,7 +256,7 @@ func RegisterUserServiceHandlerClient(ctx context.Context, mux *runtime.ServeMux
|
|||||||
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
||||||
var err error
|
var err error
|
||||||
var annotatedContext context.Context
|
var annotatedContext context.Context
|
||||||
annotatedContext, err = runtime.AnnotateContext(ctx, mux, req, "/memos.api.v2.UserService/GetUser", runtime.WithHTTPPathPattern("/api/v2/users/{name}"))
|
annotatedContext, err = runtime.AnnotateContext(ctx, mux, req, "/memos.api.v2.UserService/GetUser", runtime.WithHTTPPathPattern("/api/v2/users/{username}"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
||||||
return
|
return
|
||||||
@ -177,13 +272,39 @@ func RegisterUserServiceHandlerClient(ctx context.Context, mux *runtime.ServeMux
|
|||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
mux.Handle("PATCH", pattern_UserService_UpdateUser_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) {
|
||||||
|
ctx, cancel := context.WithCancel(req.Context())
|
||||||
|
defer cancel()
|
||||||
|
inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req)
|
||||||
|
var err error
|
||||||
|
var annotatedContext context.Context
|
||||||
|
annotatedContext, err = runtime.AnnotateContext(ctx, mux, req, "/memos.api.v2.UserService/UpdateUser", runtime.WithHTTPPathPattern("/api/v2/users/{username}"))
|
||||||
|
if err != nil {
|
||||||
|
runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
resp, md, err := request_UserService_UpdateUser_0(annotatedContext, inboundMarshaler, client, req, pathParams)
|
||||||
|
annotatedContext = runtime.NewServerMetadataContext(annotatedContext, md)
|
||||||
|
if err != nil {
|
||||||
|
runtime.HTTPError(annotatedContext, mux, outboundMarshaler, w, req, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
forward_UserService_UpdateUser_0(annotatedContext, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...)
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
pattern_UserService_GetUser_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"api", "v2", "users", "name"}, ""))
|
pattern_UserService_GetUser_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"api", "v2", "users", "username"}, ""))
|
||||||
|
|
||||||
|
pattern_UserService_UpdateUser_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"api", "v2", "users", "username"}, ""))
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
forward_UserService_GetUser_0 = runtime.ForwardResponseMessage
|
forward_UserService_GetUser_0 = runtime.ForwardResponseMessage
|
||||||
|
|
||||||
|
forward_UserService_UpdateUser_0 = runtime.ForwardResponseMessage
|
||||||
)
|
)
|
||||||
|
@ -19,7 +19,8 @@ import (
|
|||||||
const _ = grpc.SupportPackageIsVersion7
|
const _ = grpc.SupportPackageIsVersion7
|
||||||
|
|
||||||
const (
|
const (
|
||||||
UserService_GetUser_FullMethodName = "/memos.api.v2.UserService/GetUser"
|
UserService_GetUser_FullMethodName = "/memos.api.v2.UserService/GetUser"
|
||||||
|
UserService_UpdateUser_FullMethodName = "/memos.api.v2.UserService/UpdateUser"
|
||||||
)
|
)
|
||||||
|
|
||||||
// UserServiceClient is the client API for UserService service.
|
// UserServiceClient is the client API for UserService service.
|
||||||
@ -27,6 +28,7 @@ const (
|
|||||||
// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.
|
// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.
|
||||||
type UserServiceClient interface {
|
type UserServiceClient interface {
|
||||||
GetUser(ctx context.Context, in *GetUserRequest, opts ...grpc.CallOption) (*GetUserResponse, error)
|
GetUser(ctx context.Context, in *GetUserRequest, opts ...grpc.CallOption) (*GetUserResponse, error)
|
||||||
|
UpdateUser(ctx context.Context, in *UpdateUserRequest, opts ...grpc.CallOption) (*UpdateUserResponse, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type userServiceClient struct {
|
type userServiceClient struct {
|
||||||
@ -46,11 +48,21 @@ func (c *userServiceClient) GetUser(ctx context.Context, in *GetUserRequest, opt
|
|||||||
return out, nil
|
return out, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *userServiceClient) UpdateUser(ctx context.Context, in *UpdateUserRequest, opts ...grpc.CallOption) (*UpdateUserResponse, error) {
|
||||||
|
out := new(UpdateUserResponse)
|
||||||
|
err := c.cc.Invoke(ctx, UserService_UpdateUser_FullMethodName, in, out, opts...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return out, nil
|
||||||
|
}
|
||||||
|
|
||||||
// UserServiceServer is the server API for UserService service.
|
// UserServiceServer is the server API for UserService service.
|
||||||
// All implementations must embed UnimplementedUserServiceServer
|
// All implementations must embed UnimplementedUserServiceServer
|
||||||
// for forward compatibility
|
// for forward compatibility
|
||||||
type UserServiceServer interface {
|
type UserServiceServer interface {
|
||||||
GetUser(context.Context, *GetUserRequest) (*GetUserResponse, error)
|
GetUser(context.Context, *GetUserRequest) (*GetUserResponse, error)
|
||||||
|
UpdateUser(context.Context, *UpdateUserRequest) (*UpdateUserResponse, error)
|
||||||
mustEmbedUnimplementedUserServiceServer()
|
mustEmbedUnimplementedUserServiceServer()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,6 +73,9 @@ type UnimplementedUserServiceServer struct {
|
|||||||
func (UnimplementedUserServiceServer) GetUser(context.Context, *GetUserRequest) (*GetUserResponse, error) {
|
func (UnimplementedUserServiceServer) GetUser(context.Context, *GetUserRequest) (*GetUserResponse, error) {
|
||||||
return nil, status.Errorf(codes.Unimplemented, "method GetUser not implemented")
|
return nil, status.Errorf(codes.Unimplemented, "method GetUser not implemented")
|
||||||
}
|
}
|
||||||
|
func (UnimplementedUserServiceServer) UpdateUser(context.Context, *UpdateUserRequest) (*UpdateUserResponse, error) {
|
||||||
|
return nil, status.Errorf(codes.Unimplemented, "method UpdateUser not implemented")
|
||||||
|
}
|
||||||
func (UnimplementedUserServiceServer) mustEmbedUnimplementedUserServiceServer() {}
|
func (UnimplementedUserServiceServer) mustEmbedUnimplementedUserServiceServer() {}
|
||||||
|
|
||||||
// UnsafeUserServiceServer may be embedded to opt out of forward compatibility for this service.
|
// UnsafeUserServiceServer may be embedded to opt out of forward compatibility for this service.
|
||||||
@ -92,6 +107,24 @@ func _UserService_GetUser_Handler(srv interface{}, ctx context.Context, dec func
|
|||||||
return interceptor(ctx, in, info, handler)
|
return interceptor(ctx, in, info, handler)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func _UserService_UpdateUser_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
||||||
|
in := new(UpdateUserRequest)
|
||||||
|
if err := dec(in); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if interceptor == nil {
|
||||||
|
return srv.(UserServiceServer).UpdateUser(ctx, in)
|
||||||
|
}
|
||||||
|
info := &grpc.UnaryServerInfo{
|
||||||
|
Server: srv,
|
||||||
|
FullMethod: UserService_UpdateUser_FullMethodName,
|
||||||
|
}
|
||||||
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
||||||
|
return srv.(UserServiceServer).UpdateUser(ctx, req.(*UpdateUserRequest))
|
||||||
|
}
|
||||||
|
return interceptor(ctx, in, info, handler)
|
||||||
|
}
|
||||||
|
|
||||||
// UserService_ServiceDesc is the grpc.ServiceDesc for UserService service.
|
// UserService_ServiceDesc is the grpc.ServiceDesc for UserService service.
|
||||||
// It's only intended for direct use with grpc.RegisterService,
|
// It's only intended for direct use with grpc.RegisterService,
|
||||||
// and not to be introspected or modified (even as a copy)
|
// and not to be introspected or modified (even as a copy)
|
||||||
@ -103,6 +136,10 @@ var UserService_ServiceDesc = grpc.ServiceDesc{
|
|||||||
MethodName: "GetUser",
|
MethodName: "GetUser",
|
||||||
Handler: _UserService_GetUser_Handler,
|
Handler: _UserService_GetUser_Handler,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
MethodName: "UpdateUser",
|
||||||
|
Handler: _UserService_UpdateUser_Handler,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
Streams: []grpc.StreamDesc{},
|
Streams: []grpc.StreamDesc{},
|
||||||
Metadata: "api/v2/user_service.proto",
|
Metadata: "api/v2/user_service.proto",
|
||||||
|
@ -52,12 +52,12 @@ type UpdateUser struct {
|
|||||||
|
|
||||||
UpdatedTs *int64
|
UpdatedTs *int64
|
||||||
RowStatus *RowStatus
|
RowStatus *RowStatus
|
||||||
Username *string `json:"username"`
|
Username *string
|
||||||
Email *string `json:"email"`
|
Role *Role
|
||||||
Nickname *string `json:"nickname"`
|
Email *string
|
||||||
Password *string `json:"password"`
|
Nickname *string
|
||||||
ResetOpenID *bool `json:"resetOpenId"`
|
Password *string
|
||||||
AvatarURL *string `json:"avatarUrl"`
|
AvatarURL *string
|
||||||
PasswordHash *string
|
PasswordHash *string
|
||||||
OpenID *string
|
OpenID *string
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ const UsageHeatMap = () => {
|
|||||||
if (!user) {
|
if (!user) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
setCreatedDays(Math.ceil((Date.now() - getTimeStampByDate(user.createdTs)) / 1000 / 3600 / 24));
|
setCreatedDays(Math.ceil((Date.now() - getTimeStampByDate(user.createTime)) / 1000 / 3600 / 24));
|
||||||
});
|
});
|
||||||
}, [currentUsername]);
|
}, [currentUsername]);
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
import { GetUserResponse } from "@/types/proto/api/v2/user_service_pb";
|
||||||
|
|
||||||
export function getSystemStatus() {
|
export function getSystemStatus() {
|
||||||
return axios.get<SystemStatus>("/api/v1/status");
|
return axios.get<SystemStatus>("/api/v1/status");
|
||||||
@ -55,7 +56,7 @@ export function getUserList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function getUserByUsername(username: string) {
|
export function getUserByUsername(username: string) {
|
||||||
return axios.get<User>(`/api/v1/user/name/${username}`);
|
return axios.get<GetUserResponse>(`/api/v2/users/${username}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function upsertUserSetting(upsert: UserSettingUpsert) {
|
export function upsertUserSetting(upsert: UserSettingUpsert) {
|
||||||
@ -183,12 +184,8 @@ export function deleteMemoResource(memoId: MemoId, resourceId: ResourceId) {
|
|||||||
return axios.delete(`/api/v1/memo/${memoId}/resource/${resourceId}`);
|
return axios.delete(`/api/v1/memo/${memoId}/resource/${resourceId}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getTagList(tagFind?: TagFind) {
|
export function getTagList() {
|
||||||
const queryList = [];
|
return axios.get<string[]>(`/api/v1/tag`);
|
||||||
if (tagFind?.creatorUsername) {
|
|
||||||
queryList.push(`creatorUsername=${tagFind.creatorUsername}`);
|
|
||||||
}
|
|
||||||
return axios.get<string[]>(`/api/v1/tag?${queryList.join("&")}`);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getTagSuggestionList() {
|
export function getTagSuggestionList() {
|
||||||
|
@ -6,10 +6,6 @@ export function convertToMillis(localSetting: LocalSetting) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function getTimeStampByDate(t: Date | number | string): number {
|
export function getTimeStampByDate(t: Date | number | string): number {
|
||||||
if (typeof t === "string") {
|
|
||||||
t = t.replaceAll("-", "/");
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Date(t).getTime();
|
return new Date(t).getTime();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@ import UserAvatar from "@/components/UserAvatar";
|
|||||||
import useLoading from "@/hooks/useLoading";
|
import useLoading from "@/hooks/useLoading";
|
||||||
import { useMemoStore } from "@/store/module";
|
import { useMemoStore } from "@/store/module";
|
||||||
import { useUserV1Store } from "@/store/v1";
|
import { useUserV1Store } from "@/store/v1";
|
||||||
|
import { User } from "@/types/proto/api/v2/user_service_pb";
|
||||||
|
|
||||||
const MemoDetail = () => {
|
const MemoDetail = () => {
|
||||||
const params = useParams();
|
const params = useParams();
|
||||||
|
@ -7,6 +7,7 @@ import UserAvatar from "@/components/UserAvatar";
|
|||||||
import useLoading from "@/hooks/useLoading";
|
import useLoading from "@/hooks/useLoading";
|
||||||
import { useUserStore } from "@/store/module";
|
import { useUserStore } from "@/store/module";
|
||||||
import { useUserV1Store } from "@/store/v1";
|
import { useUserV1Store } from "@/store/v1";
|
||||||
|
import { User } from "@/types/proto/api/v2/user_service_pb";
|
||||||
import { useTranslate } from "@/utils/i18n";
|
import { useTranslate } from "@/utils/i18n";
|
||||||
|
|
||||||
const UserProfile = () => {
|
const UserProfile = () => {
|
||||||
|
@ -4,7 +4,7 @@ import { DEFAULT_MEMO_LIMIT } from "@/helpers/consts";
|
|||||||
import store, { useAppSelector } from "../";
|
import store, { useAppSelector } from "../";
|
||||||
import { createMemo, deleteMemo, patchMemo, upsertMemos } from "../reducer/memo";
|
import { createMemo, deleteMemo, patchMemo, upsertMemos } from "../reducer/memo";
|
||||||
import { useMemoCacheStore } from "../v1";
|
import { useMemoCacheStore } from "../v1";
|
||||||
import { useUserStore } from "./";
|
import { getUsernameFromPath, useUserStore } from "./";
|
||||||
|
|
||||||
export const convertResponseModelMemo = (memo: Memo): Memo => {
|
export const convertResponseModelMemo = (memo: Memo): Memo => {
|
||||||
return {
|
return {
|
||||||
@ -40,7 +40,7 @@ export const useMemoStore = () => {
|
|||||||
offset,
|
offset,
|
||||||
};
|
};
|
||||||
if (userStore.isVisitorMode()) {
|
if (userStore.isVisitorMode()) {
|
||||||
memoFind.creatorUsername = userStore.getUsernameFromPath();
|
memoFind.creatorUsername = getUsernameFromPath();
|
||||||
}
|
}
|
||||||
const { data } = await api.getMemoList(memoFind);
|
const { data } = await api.getMemoList(memoFind);
|
||||||
const fetchedMemos = data.map((m) => convertResponseModelMemo(m));
|
const fetchedMemos = data.map((m) => convertResponseModelMemo(m));
|
||||||
@ -70,9 +70,6 @@ export const useMemoStore = () => {
|
|||||||
const memoFind: MemoFind = {
|
const memoFind: MemoFind = {
|
||||||
rowStatus: "ARCHIVED",
|
rowStatus: "ARCHIVED",
|
||||||
};
|
};
|
||||||
if (userStore.isVisitorMode()) {
|
|
||||||
memoFind.creatorUsername = userStore.getUsernameFromPath();
|
|
||||||
}
|
|
||||||
const { data } = await api.getMemoList(memoFind);
|
const { data } = await api.getMemoList(memoFind);
|
||||||
const archivedMemos = data.map((m) => {
|
const archivedMemos = data.map((m) => {
|
||||||
return convertResponseModelMemo(m);
|
return convertResponseModelMemo(m);
|
||||||
|
@ -1,22 +1,17 @@
|
|||||||
import * as api from "@/helpers/api";
|
import * as api from "@/helpers/api";
|
||||||
import store, { useAppSelector } from "..";
|
import store, { useAppSelector } from "..";
|
||||||
import { deleteTag, setTags, upsertTag } from "../reducer/tag";
|
import { deleteTag, setTags, upsertTag } from "../reducer/tag";
|
||||||
import { useUserStore } from "./";
|
|
||||||
|
|
||||||
export const useTagStore = () => {
|
export const useTagStore = () => {
|
||||||
const state = useAppSelector((state) => state.tag);
|
const state = useAppSelector((state) => state.tag);
|
||||||
const userStore = useUserStore();
|
|
||||||
return {
|
return {
|
||||||
state,
|
state,
|
||||||
getState: () => {
|
getState: () => {
|
||||||
return store.getState().tag;
|
return store.getState().tag;
|
||||||
},
|
},
|
||||||
fetchTags: async () => {
|
fetchTags: async () => {
|
||||||
const tagFind: TagFind = {};
|
const { data } = await api.getTagList();
|
||||||
if (userStore.isVisitorMode()) {
|
|
||||||
tagFind.creatorUsername = userStore.getUsernameFromPath();
|
|
||||||
}
|
|
||||||
const { data } = await api.getTagList(tagFind);
|
|
||||||
store.dispatch(setTags(data));
|
store.dispatch(setTags(data));
|
||||||
},
|
},
|
||||||
upsertTag: async (tagName: string) => {
|
upsertTag: async (tagName: string) => {
|
||||||
|
@ -71,16 +71,6 @@ export const initialUserState = async () => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const getUsernameFromPath = () => {
|
|
||||||
const pathname = window.location.pathname;
|
|
||||||
const usernameRegex = /^\/u\/(\w+).*/;
|
|
||||||
const result = pathname.match(usernameRegex);
|
|
||||||
if (result && result.length === 2) {
|
|
||||||
return String(result[1]);
|
|
||||||
}
|
|
||||||
return undefined;
|
|
||||||
};
|
|
||||||
|
|
||||||
const doSignIn = async () => {
|
const doSignIn = async () => {
|
||||||
const { data: user } = await api.getMyselfUser();
|
const { data: user } = await api.getMyselfUser();
|
||||||
if (user) {
|
if (user) {
|
||||||
@ -95,6 +85,16 @@ const doSignOut = async () => {
|
|||||||
await api.signout();
|
await api.signout();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const getUsernameFromPath = () => {
|
||||||
|
const pathname = window.location.pathname;
|
||||||
|
const usernameRegex = /^\/u\/(\w+).*/;
|
||||||
|
const result = pathname.match(usernameRegex);
|
||||||
|
if (result && result.length === 2) {
|
||||||
|
return String(result[1]);
|
||||||
|
}
|
||||||
|
return undefined;
|
||||||
|
};
|
||||||
|
|
||||||
export const useUserStore = () => {
|
export const useUserStore = () => {
|
||||||
const state = useAppSelector((state) => state.user);
|
const state = useAppSelector((state) => state.user);
|
||||||
|
|
||||||
@ -108,7 +108,6 @@ export const useUserStore = () => {
|
|||||||
return store.getState().user;
|
return store.getState().user;
|
||||||
},
|
},
|
||||||
isVisitorMode,
|
isVisitorMode,
|
||||||
getUsernameFromPath,
|
|
||||||
doSignIn,
|
doSignIn,
|
||||||
doSignOut,
|
doSignOut,
|
||||||
getCurrentUsername: () => {
|
getCurrentUsername: () => {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { create } from "zustand";
|
import { create } from "zustand";
|
||||||
import * as api from "@/helpers/api";
|
import * as api from "@/helpers/api";
|
||||||
import { convertResponseModelUser } from "../module";
|
import { User } from "@/types/proto/api/v2/user_service_pb";
|
||||||
|
|
||||||
interface UserV1Store {
|
interface UserV1Store {
|
||||||
userMapByUsername: Record<string, User>;
|
userMapByUsername: Record<string, User>;
|
||||||
@ -24,9 +24,13 @@ const useUserV1Store = create<UserV1Store>()((set, get) => ({
|
|||||||
|
|
||||||
const promise = api.getUserByUsername(username);
|
const promise = api.getUserByUsername(username);
|
||||||
requestCache.set(username, promise);
|
requestCache.set(username, promise);
|
||||||
const { data } = await promise;
|
const {
|
||||||
|
data: { user: user },
|
||||||
|
} = await promise;
|
||||||
|
if (!user) {
|
||||||
|
throw new Error("User not found");
|
||||||
|
}
|
||||||
requestCache.delete(username);
|
requestCache.delete(username);
|
||||||
const user = convertResponseModelUser(data);
|
|
||||||
userMap[username] = user;
|
userMap[username] = user;
|
||||||
set(userMap);
|
set(userMap);
|
||||||
return user;
|
return user;
|
||||||
|
213
web/src/types/proto/api/v2/user_service_pb.d.ts
vendored
213
web/src/types/proto/api/v2/user_service_pb.d.ts
vendored
@ -3,15 +3,89 @@
|
|||||||
/* eslint-disable */
|
/* eslint-disable */
|
||||||
// @ts-nocheck
|
// @ts-nocheck
|
||||||
|
|
||||||
import type { BinaryReadOptions, FieldList, JsonReadOptions, JsonValue, PartialMessage, PlainMessage } from "@bufbuild/protobuf";
|
import type { BinaryReadOptions, FieldList, FieldMask, JsonReadOptions, JsonValue, PartialMessage, PlainMessage, Timestamp } from "@bufbuild/protobuf";
|
||||||
import { Message, proto3 } from "@bufbuild/protobuf";
|
import { Message, proto3 } from "@bufbuild/protobuf";
|
||||||
import type { RowStatus } from "./common_pb.js";
|
import type { RowStatus } from "./common_pb.js";
|
||||||
import type { Visibility } from "./memo_service_pb.js";
|
import type { Visibility } from "./memo_service_pb.js";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @generated from enum memos.api.v2.Role
|
* @generated from message memos.api.v2.User
|
||||||
*/
|
*/
|
||||||
export declare enum Role {
|
export declare class User extends Message<User> {
|
||||||
|
/**
|
||||||
|
* @generated from field: int32 id = 1;
|
||||||
|
*/
|
||||||
|
id: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: memos.api.v2.RowStatus row_status = 2;
|
||||||
|
*/
|
||||||
|
rowStatus: RowStatus;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: google.protobuf.Timestamp create_time = 3;
|
||||||
|
*/
|
||||||
|
createTime?: Timestamp;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: google.protobuf.Timestamp update_time = 4;
|
||||||
|
*/
|
||||||
|
updateTime?: Timestamp;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string username = 5;
|
||||||
|
*/
|
||||||
|
username: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: memos.api.v2.User.Role role = 6;
|
||||||
|
*/
|
||||||
|
role: User_Role;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string email = 7;
|
||||||
|
*/
|
||||||
|
email: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string nickname = 8;
|
||||||
|
*/
|
||||||
|
nickname: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string open_id = 9;
|
||||||
|
*/
|
||||||
|
openId: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string avatar_url = 10;
|
||||||
|
*/
|
||||||
|
avatarUrl: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: string password = 11;
|
||||||
|
*/
|
||||||
|
password: string;
|
||||||
|
|
||||||
|
constructor(data?: PartialMessage<User>);
|
||||||
|
|
||||||
|
static readonly runtime: typeof proto3;
|
||||||
|
static readonly typeName = "memos.api.v2.User";
|
||||||
|
static readonly fields: FieldList;
|
||||||
|
|
||||||
|
static fromBinary(bytes: Uint8Array, options?: Partial<BinaryReadOptions>): User;
|
||||||
|
|
||||||
|
static fromJson(jsonValue: JsonValue, options?: Partial<JsonReadOptions>): User;
|
||||||
|
|
||||||
|
static fromJsonString(jsonString: string, options?: Partial<JsonReadOptions>): User;
|
||||||
|
|
||||||
|
static equals(a: User | PlainMessage<User> | undefined, b: User | PlainMessage<User> | undefined): boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from enum memos.api.v2.User.Role
|
||||||
|
*/
|
||||||
|
export declare enum User_Role {
|
||||||
/**
|
/**
|
||||||
* @generated from enum value: ROLE_UNSPECIFIED = 0;
|
* @generated from enum value: ROLE_UNSPECIFIED = 0;
|
||||||
*/
|
*/
|
||||||
@ -33,83 +107,14 @@ export declare enum Role {
|
|||||||
USER = 3,
|
USER = 3,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from message memos.api.v2.User
|
|
||||||
*/
|
|
||||||
export declare class User extends Message<User> {
|
|
||||||
/**
|
|
||||||
* @generated from field: int32 id = 1;
|
|
||||||
*/
|
|
||||||
id: number;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: memos.api.v2.RowStatus row_status = 2;
|
|
||||||
*/
|
|
||||||
rowStatus: RowStatus;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: int64 created_ts = 3;
|
|
||||||
*/
|
|
||||||
createdTs: bigint;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: int64 updated_ts = 4;
|
|
||||||
*/
|
|
||||||
updatedTs: bigint;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: string username = 5;
|
|
||||||
*/
|
|
||||||
username: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: memos.api.v2.Role role = 6;
|
|
||||||
*/
|
|
||||||
role: Role;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: string email = 7;
|
|
||||||
*/
|
|
||||||
email: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: string nickname = 8;
|
|
||||||
*/
|
|
||||||
nickname: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: string open_id = 9;
|
|
||||||
*/
|
|
||||||
openId: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from field: string avatar_url = 10;
|
|
||||||
*/
|
|
||||||
avatarUrl: string;
|
|
||||||
|
|
||||||
constructor(data?: PartialMessage<User>);
|
|
||||||
|
|
||||||
static readonly runtime: typeof proto3;
|
|
||||||
static readonly typeName = "memos.api.v2.User";
|
|
||||||
static readonly fields: FieldList;
|
|
||||||
|
|
||||||
static fromBinary(bytes: Uint8Array, options?: Partial<BinaryReadOptions>): User;
|
|
||||||
|
|
||||||
static fromJson(jsonValue: JsonValue, options?: Partial<JsonReadOptions>): User;
|
|
||||||
|
|
||||||
static fromJsonString(jsonString: string, options?: Partial<JsonReadOptions>): User;
|
|
||||||
|
|
||||||
static equals(a: User | PlainMessage<User> | undefined, b: User | PlainMessage<User> | undefined): boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @generated from message memos.api.v2.GetUserRequest
|
* @generated from message memos.api.v2.GetUserRequest
|
||||||
*/
|
*/
|
||||||
export declare class GetUserRequest extends Message<GetUserRequest> {
|
export declare class GetUserRequest extends Message<GetUserRequest> {
|
||||||
/**
|
/**
|
||||||
* @generated from field: string name = 1;
|
* @generated from field: string username = 1;
|
||||||
*/
|
*/
|
||||||
name: string;
|
username: string;
|
||||||
|
|
||||||
constructor(data?: PartialMessage<GetUserRequest>);
|
constructor(data?: PartialMessage<GetUserRequest>);
|
||||||
|
|
||||||
@ -150,6 +155,66 @@ export declare class GetUserResponse extends Message<GetUserResponse> {
|
|||||||
static equals(a: GetUserResponse | PlainMessage<GetUserResponse> | undefined, b: GetUserResponse | PlainMessage<GetUserResponse> | undefined): boolean;
|
static equals(a: GetUserResponse | PlainMessage<GetUserResponse> | undefined, b: GetUserResponse | PlainMessage<GetUserResponse> | undefined): boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from message memos.api.v2.UpdateUserRequest
|
||||||
|
*/
|
||||||
|
export declare class UpdateUserRequest extends Message<UpdateUserRequest> {
|
||||||
|
/**
|
||||||
|
* @generated from field: string username = 1;
|
||||||
|
*/
|
||||||
|
username: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from field: memos.api.v2.User user = 2;
|
||||||
|
*/
|
||||||
|
user?: User;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The update mask applies to the user resource.
|
||||||
|
*
|
||||||
|
* @generated from field: google.protobuf.FieldMask update_mask = 3;
|
||||||
|
*/
|
||||||
|
updateMask?: FieldMask;
|
||||||
|
|
||||||
|
constructor(data?: PartialMessage<UpdateUserRequest>);
|
||||||
|
|
||||||
|
static readonly runtime: typeof proto3;
|
||||||
|
static readonly typeName = "memos.api.v2.UpdateUserRequest";
|
||||||
|
static readonly fields: FieldList;
|
||||||
|
|
||||||
|
static fromBinary(bytes: Uint8Array, options?: Partial<BinaryReadOptions>): UpdateUserRequest;
|
||||||
|
|
||||||
|
static fromJson(jsonValue: JsonValue, options?: Partial<JsonReadOptions>): UpdateUserRequest;
|
||||||
|
|
||||||
|
static fromJsonString(jsonString: string, options?: Partial<JsonReadOptions>): UpdateUserRequest;
|
||||||
|
|
||||||
|
static equals(a: UpdateUserRequest | PlainMessage<UpdateUserRequest> | undefined, b: UpdateUserRequest | PlainMessage<UpdateUserRequest> | undefined): boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from message memos.api.v2.UpdateUserResponse
|
||||||
|
*/
|
||||||
|
export declare class UpdateUserResponse extends Message<UpdateUserResponse> {
|
||||||
|
/**
|
||||||
|
* @generated from field: memos.api.v2.User user = 1;
|
||||||
|
*/
|
||||||
|
user?: User;
|
||||||
|
|
||||||
|
constructor(data?: PartialMessage<UpdateUserResponse>);
|
||||||
|
|
||||||
|
static readonly runtime: typeof proto3;
|
||||||
|
static readonly typeName = "memos.api.v2.UpdateUserResponse";
|
||||||
|
static readonly fields: FieldList;
|
||||||
|
|
||||||
|
static fromBinary(bytes: Uint8Array, options?: Partial<BinaryReadOptions>): UpdateUserResponse;
|
||||||
|
|
||||||
|
static fromJson(jsonValue: JsonValue, options?: Partial<JsonReadOptions>): UpdateUserResponse;
|
||||||
|
|
||||||
|
static fromJsonString(jsonString: string, options?: Partial<JsonReadOptions>): UpdateUserResponse;
|
||||||
|
|
||||||
|
static equals(a: UpdateUserResponse | PlainMessage<UpdateUserResponse> | undefined, b: UpdateUserResponse | PlainMessage<UpdateUserResponse> | undefined): boolean;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @generated from message memos.api.v2.UserSetting
|
* @generated from message memos.api.v2.UserSetting
|
||||||
*/
|
*/
|
||||||
|
@ -3,23 +3,10 @@
|
|||||||
/* eslint-disable */
|
/* eslint-disable */
|
||||||
// @ts-nocheck
|
// @ts-nocheck
|
||||||
|
|
||||||
import { proto3 } from "@bufbuild/protobuf";
|
import { FieldMask, proto3, Timestamp } from "@bufbuild/protobuf";
|
||||||
import { RowStatus } from "./common_pb.js";
|
import { RowStatus } from "./common_pb.js";
|
||||||
import { Visibility } from "./memo_service_pb.js";
|
import { Visibility } from "./memo_service_pb.js";
|
||||||
|
|
||||||
/**
|
|
||||||
* @generated from enum memos.api.v2.Role
|
|
||||||
*/
|
|
||||||
export const Role = proto3.makeEnum(
|
|
||||||
"memos.api.v2.Role",
|
|
||||||
[
|
|
||||||
{no: 0, name: "ROLE_UNSPECIFIED"},
|
|
||||||
{no: 1, name: "HOST"},
|
|
||||||
{no: 2, name: "ADMIN"},
|
|
||||||
{no: 3, name: "USER"},
|
|
||||||
],
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @generated from message memos.api.v2.User
|
* @generated from message memos.api.v2.User
|
||||||
*/
|
*/
|
||||||
@ -28,14 +15,28 @@ export const User = proto3.makeMessageType(
|
|||||||
() => [
|
() => [
|
||||||
{ no: 1, name: "id", kind: "scalar", T: 5 /* ScalarType.INT32 */ },
|
{ no: 1, name: "id", kind: "scalar", T: 5 /* ScalarType.INT32 */ },
|
||||||
{ no: 2, name: "row_status", kind: "enum", T: proto3.getEnumType(RowStatus) },
|
{ no: 2, name: "row_status", kind: "enum", T: proto3.getEnumType(RowStatus) },
|
||||||
{ no: 3, name: "created_ts", kind: "scalar", T: 3 /* ScalarType.INT64 */ },
|
{ no: 3, name: "create_time", kind: "message", T: Timestamp },
|
||||||
{ no: 4, name: "updated_ts", kind: "scalar", T: 3 /* ScalarType.INT64 */ },
|
{ no: 4, name: "update_time", kind: "message", T: Timestamp },
|
||||||
{ no: 5, name: "username", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 5, name: "username", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
{ no: 6, name: "role", kind: "enum", T: proto3.getEnumType(Role) },
|
{ no: 6, name: "role", kind: "enum", T: proto3.getEnumType(User_Role) },
|
||||||
{ no: 7, name: "email", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 7, name: "email", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
{ no: 8, name: "nickname", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 8, name: "nickname", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
{ no: 9, name: "open_id", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 9, name: "open_id", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
{ no: 10, name: "avatar_url", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 10, name: "avatar_url", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
|
{ no: 11, name: "password", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from enum memos.api.v2.User.Role
|
||||||
|
*/
|
||||||
|
export const User_Role = proto3.makeEnum(
|
||||||
|
"memos.api.v2.User.Role",
|
||||||
|
[
|
||||||
|
{no: 0, name: "ROLE_UNSPECIFIED"},
|
||||||
|
{no: 1, name: "HOST"},
|
||||||
|
{no: 2, name: "ADMIN"},
|
||||||
|
{no: 3, name: "USER"},
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -45,7 +46,7 @@ export const User = proto3.makeMessageType(
|
|||||||
export const GetUserRequest = proto3.makeMessageType(
|
export const GetUserRequest = proto3.makeMessageType(
|
||||||
"memos.api.v2.GetUserRequest",
|
"memos.api.v2.GetUserRequest",
|
||||||
() => [
|
() => [
|
||||||
{ no: 1, name: "name", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
{ no: 1, name: "username", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -59,6 +60,28 @@ export const GetUserResponse = proto3.makeMessageType(
|
|||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from message memos.api.v2.UpdateUserRequest
|
||||||
|
*/
|
||||||
|
export const UpdateUserRequest = proto3.makeMessageType(
|
||||||
|
"memos.api.v2.UpdateUserRequest",
|
||||||
|
() => [
|
||||||
|
{ no: 1, name: "username", kind: "scalar", T: 9 /* ScalarType.STRING */ },
|
||||||
|
{ no: 2, name: "user", kind: "message", T: User },
|
||||||
|
{ no: 3, name: "update_mask", kind: "message", T: FieldMask },
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @generated from message memos.api.v2.UpdateUserResponse
|
||||||
|
*/
|
||||||
|
export const UpdateUserResponse = proto3.makeMessageType(
|
||||||
|
"memos.api.v2.UpdateUserResponse",
|
||||||
|
() => [
|
||||||
|
{ no: 1, name: "user", kind: "message", T: User },
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @generated from message memos.api.v2.UserSetting
|
* @generated from message memos.api.v2.UserSetting
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user