mirror of
				https://github.com/usememos/memos.git
				synced 2025-10-26 22:36:16 +08:00 
			
		
		
		
	| .. | ||
| activity_service.pb.go | ||
| activity_service.pb.gw.go | ||
| activity_service_grpc.pb.go | ||
| auth_service.pb.go | ||
| auth_service.pb.gw.go | ||
| auth_service_grpc.pb.go | ||
| common.pb.go | ||
| inbox_service.pb.go | ||
| inbox_service.pb.gw.go | ||
| inbox_service_grpc.pb.go | ||
| markdown_service.pb.go | ||
| markdown_service.pb.gw.go | ||
| markdown_service_grpc.pb.go | ||
| memo_service.pb.go | ||
| memo_service.pb.gw.go | ||
| memo_service_grpc.pb.go | ||
| README.md | ||
| resource_service.pb.go | ||
| resource_service.pb.gw.go | ||
| resource_service_grpc.pb.go | ||
| system_service.pb.go | ||
| system_service.pb.gw.go | ||
| system_service_grpc.pb.go | ||
| tag_service.pb.go | ||
| tag_service.pb.gw.go | ||
| tag_service_grpc.pb.go | ||
| user_service.pb.go | ||
| user_service.pb.gw.go | ||
| user_service_grpc.pb.go | ||
| webhook_service.pb.go | ||
| webhook_service.pb.gw.go | ||
| webhook_service_grpc.pb.go | ||
Protocol Documentation
Table of Contents
api/v2/activity_service.proto
Activity
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | ||
| creator_id | int32 | ||
| type | string | ||
| level | string | ||
| create_time | google.protobuf.Timestamp | ||
| payload | ActivityPayload | 
ActivityMemoCommentPayload
| Field | Type | Label | Description | 
|---|---|---|---|
| memo_id | int32 | ||
| related_memo_id | int32 | 
ActivityPayload
| Field | Type | Label | Description | 
|---|---|---|---|
| memo_comment | ActivityMemoCommentPayload | ||
| version_update | ActivityVersionUpdatePayload | 
ActivityVersionUpdatePayload
| Field | Type | Label | Description | 
|---|---|---|---|
| version | string | 
GetActivityRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
GetActivityResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| activity | Activity | 
ActivityService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| GetActivity | GetActivityRequest | GetActivityResponse | 
api/v2/common.proto
RowStatus
| Name | Number | Description | 
|---|---|---|
| ROW_STATUS_UNSPECIFIED | 0 | |
| ACTIVE | 1 | |
| ARCHIVED | 2 | 
api/v2/user_service.proto
CreateUserAccessTokenRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | |
| description | string | ||
| expires_at | google.protobuf.Timestamp | optional | 
CreateUserAccessTokenResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| access_token | UserAccessToken | 
CreateUserRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | 
CreateUserResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | 
DeleteUserAccessTokenRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | |
| access_token | string | access_token is the access token to delete. | 
DeleteUserAccessTokenResponse
DeleteUserRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | 
DeleteUserResponse
GetUserRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | 
GetUserResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | 
GetUserSettingRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | 
GetUserSettingResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| setting | UserSetting | 
ListUserAccessTokensRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | 
ListUserAccessTokensResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| access_tokens | UserAccessToken | repeated | 
UpdateUserRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | ||
| update_mask | google.protobuf.FieldMask | 
UpdateUserResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | 
UpdateUserSettingRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| setting | UserSetting | ||
| update_mask | google.protobuf.FieldMask | 
UpdateUserSettingResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| setting | UserSetting | 
User
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | |
| id | int32 | ||
| role | User.Role | ||
| string | |||
| nickname | string | ||
| avatar_url | string | ||
| password | string | ||
| row_status | RowStatus | ||
| create_time | google.protobuf.Timestamp | ||
| update_time | google.protobuf.Timestamp | 
UserAccessToken
| Field | Type | Label | Description | 
|---|---|---|---|
| access_token | string | ||
| description | string | ||
| issued_at | google.protobuf.Timestamp | ||
| expires_at | google.protobuf.Timestamp | 
UserSetting
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the user. Format: users/{username} | |
| locale | string | The preferred locale of the user. | |
| appearance | string | The preferred appearance of the user. | |
| memo_visibility | string | The default visibility of the memo. | |
| telegram_user_id | string | The telegram user id of the user. | 
User.Role
| Name | Number | Description | 
|---|---|---|
| ROLE_UNSPECIFIED | 0 | |
| HOST | 1 | |
| ADMIN | 2 | |
| USER | 3 | 
UserService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| GetUser | GetUserRequest | GetUserResponse | GetUser gets a user by name. | 
| CreateUser | CreateUserRequest | CreateUserResponse | CreateUser creates a new user. | 
| UpdateUser | UpdateUserRequest | UpdateUserResponse | UpdateUser updates a user. | 
| DeleteUser | DeleteUserRequest | DeleteUserResponse | DeleteUser deletes a user. | 
| GetUserSetting | GetUserSettingRequest | GetUserSettingResponse | |
| UpdateUserSetting | UpdateUserSettingRequest | UpdateUserSettingResponse | |
| ListUserAccessTokens | ListUserAccessTokensRequest | ListUserAccessTokensResponse | ListUserAccessTokens returns a list of access tokens for a user. | 
| CreateUserAccessToken | CreateUserAccessTokenRequest | CreateUserAccessTokenResponse | CreateUserAccessToken creates a new access token for a user. | 
| DeleteUserAccessToken | DeleteUserAccessTokenRequest | DeleteUserAccessTokenResponse | DeleteUserAccessToken deletes an access token for a user. | 
api/v2/auth_service.proto
GetAuthStatusRequest
GetAuthStatusResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| user | User | 
AuthService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| GetAuthStatus | GetAuthStatusRequest | GetAuthStatusResponse | 
api/v2/inbox_service.proto
DeleteInboxRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the inbox to delete. Format: inboxes/{inbox} | 
DeleteInboxResponse
Inbox
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | The name of the inbox. Format: inboxes/{id} | |
| sender | string | Format: users/{username} | |
| receiver | string | Format: users/{username} | |
| status | Inbox.Status | ||
| create_time | google.protobuf.Timestamp | ||
| type | Inbox.Type | ||
| activity_id | int32 | optional | 
ListInboxesRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| user | string | Format: users/{username} | 
ListInboxesResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| inboxes | Inbox | repeated | 
UpdateInboxRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| inbox | Inbox | ||
| update_mask | google.protobuf.FieldMask | 
UpdateInboxResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| inbox | Inbox | 
Inbox.Status
| Name | Number | Description | 
|---|---|---|
| STATUS_UNSPECIFIED | 0 | |
| UNREAD | 1 | |
| ARCHIVED | 2 | 
Inbox.Type
| Name | Number | Description | 
|---|---|---|
| TYPE_UNSPECIFIED | 0 | |
| TYPE_MEMO_COMMENT | 1 | |
| TYPE_VERSION_UPDATE | 2 | 
InboxService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| ListInboxes | ListInboxesRequest | ListInboxesResponse | |
| UpdateInbox | UpdateInboxRequest | UpdateInboxResponse | |
| DeleteInbox | DeleteInboxRequest | DeleteInboxResponse | 
api/v2/markdown_service.proto
BlockquoteNode
| Field | Type | Label | Description | 
|---|---|---|---|
| children | Node | repeated | 
BoldItalicNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | ||
| content | string | 
BoldNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | ||
| children | Node | repeated | 
CodeBlockNode
| Field | Type | Label | Description | 
|---|---|---|---|
| language | string | ||
| content | string | 
CodeNode
| Field | Type | Label | Description | 
|---|---|---|---|
| content | string | 
EscapingCharacterNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | 
HeadingNode
| Field | Type | Label | Description | 
|---|---|---|---|
| level | int32 | ||
| children | Node | repeated | 
HorizontalRuleNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | 
ImageNode
| Field | Type | Label | Description | 
|---|---|---|---|
| alt_text | string | ||
| url | string | 
ItalicNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | ||
| content | string | 
LineBreakNode
LinkNode
| Field | Type | Label | Description | 
|---|---|---|---|
| text | string | ||
| url | string | 
Node
| Field | Type | Label | Description | 
|---|---|---|---|
| type | NodeType | ||
| line_break_node | LineBreakNode | ||
| paragraph_node | ParagraphNode | ||
| code_block_node | CodeBlockNode | ||
| heading_node | HeadingNode | ||
| horizontal_rule_node | HorizontalRuleNode | ||
| blockquote_node | BlockquoteNode | ||
| ordered_list_node | OrderedListNode | ||
| unordered_list_node | UnorderedListNode | ||
| task_list_node | TaskListNode | ||
| text_node | TextNode | ||
| bold_node | BoldNode | ||
| italic_node | ItalicNode | ||
| bold_italic_node | BoldItalicNode | ||
| code_node | CodeNode | ||
| image_node | ImageNode | ||
| link_node | LinkNode | ||
| tag_node | TagNode | ||
| strikethrough_node | StrikethroughNode | ||
| escaping_character_node | EscapingCharacterNode | 
OrderedListNode
| Field | Type | Label | Description | 
|---|---|---|---|
| number | string | ||
| children | Node | repeated | 
ParagraphNode
| Field | Type | Label | Description | 
|---|---|---|---|
| children | Node | repeated | 
ParseMarkdownRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| markdown | string | 
ParseMarkdownResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| nodes | Node | repeated | 
StrikethroughNode
| Field | Type | Label | Description | 
|---|---|---|---|
| content | string | 
TagNode
| Field | Type | Label | Description | 
|---|---|---|---|
| content | string | 
TaskListNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | ||
| complete | bool | ||
| children | Node | repeated | 
TextNode
| Field | Type | Label | Description | 
|---|---|---|---|
| content | string | 
UnorderedListNode
| Field | Type | Label | Description | 
|---|---|---|---|
| symbol | string | ||
| children | Node | repeated | 
NodeType
| Name | Number | Description | 
|---|---|---|
| NODE_UNSPECIFIED | 0 | |
| LINE_BREAK | 1 | |
| PARAGRAPH | 2 | |
| CODE_BLOCK | 3 | |
| HEADING | 4 | |
| HORIZONTAL_RULE | 5 | |
| BLOCKQUOTE | 6 | |
| ORDERED_LIST | 7 | |
| UNORDERED_LIST | 8 | |
| TASK_LIST | 9 | |
| TEXT | 10 | |
| BOLD | 11 | |
| ITALIC | 12 | |
| BOLD_ITALIC | 13 | |
| CODE | 14 | |
| IMAGE | 15 | |
| LINK | 16 | |
| TAG | 17 | |
| STRIKETHROUGH | 18 | |
| ESCAPING_CHARACTER | 19 | 
MarkdownService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| ParseMarkdown | ParseMarkdownRequest | ParseMarkdownResponse | 
api/v2/memo_service.proto
CreateMemoCommentRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | id is the memo id to create comment for. | |
| create | CreateMemoRequest | 
CreateMemoCommentResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| memo | Memo | 
CreateMemoRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| content | string | ||
| visibility | Visibility | 
CreateMemoResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| memo | Memo | 
GetMemoRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
GetMemoResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| memo | Memo | 
ListMemoCommentsRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
ListMemoCommentsResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| memos | Memo | repeated | 
ListMemosRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| page | int32 | ||
| page_size | int32 | ||
| filter | string | Filter is used to filter memos returned in the list. | |
| creator_id | int32 | optional | 
ListMemosResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| memos | Memo | repeated | 
Memo
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | ||
| row_status | RowStatus | ||
| creator_id | int32 | ||
| created_ts | int64 | ||
| updated_ts | int64 | ||
| content | string | ||
| nodes | Node | repeated | |
| visibility | Visibility | ||
| pinned | bool | 
Visibility
| Name | Number | Description | 
|---|---|---|
| VISIBILITY_UNSPECIFIED | 0 | |
| PRIVATE | 1 | |
| PROTECTED | 2 | |
| PUBLIC | 3 | 
MemoService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| CreateMemo | CreateMemoRequest | CreateMemoResponse | |
| ListMemos | ListMemosRequest | ListMemosResponse | |
| GetMemo | GetMemoRequest | GetMemoResponse | |
| CreateMemoComment | CreateMemoCommentRequest | CreateMemoCommentResponse | |
| ListMemoComments | ListMemoCommentsRequest | ListMemoCommentsResponse | 
api/v2/resource_service.proto
CreateResourceRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| filename | string | ||
| external_link | string | ||
| type | string | ||
| memo_id | int32 | optional | 
CreateResourceResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| resource | Resource | 
DeleteResourceRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
DeleteResourceResponse
ListResourcesRequest
ListResourcesResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| resources | Resource | repeated | 
Resource
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | ||
| created_ts | google.protobuf.Timestamp | ||
| filename | string | ||
| external_link | string | ||
| type | string | ||
| size | int64 | ||
| memo_id | int32 | optional | 
UpdateResourceRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| resource | Resource | ||
| update_mask | google.protobuf.FieldMask | 
UpdateResourceResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| resource | Resource | 
ResourceService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| CreateResource | CreateResourceRequest | CreateResourceResponse | |
| ListResources | ListResourcesRequest | ListResourcesResponse | |
| UpdateResource | UpdateResourceRequest | UpdateResourceResponse | |
| DeleteResource | DeleteResourceRequest | DeleteResourceResponse | 
api/v2/system_service.proto
GetSystemInfoRequest
GetSystemInfoResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| system_info | SystemInfo | 
SystemInfo
| Field | Type | Label | Description | 
|---|---|---|---|
| version | string | ||
| mode | string | ||
| allow_registration | bool | ||
| disable_password_login | bool | ||
| additional_script | string | ||
| additional_style | string | ||
| db_size | int64 | 
UpdateSystemInfoRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| system_info | SystemInfo | System info is the updated data. | |
| update_mask | google.protobuf.FieldMask | 
UpdateSystemInfoResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| system_info | SystemInfo | 
SystemService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| GetSystemInfo | GetSystemInfoRequest | GetSystemInfoResponse | |
| UpdateSystemInfo | UpdateSystemInfoRequest | UpdateSystemInfoResponse | 
api/v2/tag_service.proto
DeleteTagRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| tag | Tag | 
DeleteTagResponse
GetTagSuggestionsRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| user | string | The creator of tags. Format: users/{username} | 
GetTagSuggestionsResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| tags | string | repeated | 
ListTagsRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| user | string | The creator of tags. Format: users/{username} | 
ListTagsResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| tags | Tag | repeated | 
Tag
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | ||
| creator | string | The creator of tags. Format: users/{username} | 
UpsertTagRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | 
UpsertTagResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| tag | Tag | 
TagService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| UpsertTag | UpsertTagRequest | UpsertTagResponse | |
| ListTags | ListTagsRequest | ListTagsResponse | |
| DeleteTag | DeleteTagRequest | DeleteTagResponse | |
| GetTagSuggestions | GetTagSuggestionsRequest | GetTagSuggestionsResponse | 
api/v2/webhook_service.proto
CreateWebhookRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| name | string | ||
| url | string | 
CreateWebhookResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| webhook | Webhook | 
DeleteWebhookRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
DeleteWebhookResponse
GetWebhookRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | 
GetWebhookResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| webhook | Webhook | 
ListWebhooksRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| creator_id | int32 | 
ListWebhooksResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| webhooks | Webhook | repeated | 
UpdateWebhookRequest
| Field | Type | Label | Description | 
|---|---|---|---|
| webhook | Webhook | ||
| update_mask | google.protobuf.FieldMask | 
UpdateWebhookResponse
| Field | Type | Label | Description | 
|---|---|---|---|
| webhook | Webhook | 
Webhook
| Field | Type | Label | Description | 
|---|---|---|---|
| id | int32 | ||
| creator_id | int32 | ||
| created_time | google.protobuf.Timestamp | ||
| updated_time | google.protobuf.Timestamp | ||
| row_status | RowStatus | ||
| name | string | ||
| url | string | 
WebhookService
| Method Name | Request Type | Response Type | Description | 
|---|---|---|---|
| CreateWebhook | CreateWebhookRequest | CreateWebhookResponse | |
| GetWebhook | GetWebhookRequest | GetWebhookResponse | |
| ListWebhooks | ListWebhooksRequest | ListWebhooksResponse | |
| UpdateWebhook | UpdateWebhookRequest | UpdateWebhookResponse | |
| DeleteWebhook | DeleteWebhookRequest | DeleteWebhookResponse | 
Scalar Value Types
| .proto Type | Notes | C++ | Java | Python | Go | C# | PHP | Ruby | 
|---|---|---|---|---|---|---|---|---|
| double | double | double | float | float64 | double | float | Float | |
| float | float | float | float | float32 | float | float | Float | |
| int32 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint32 instead. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) | 
| int64 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint64 instead. | int64 | long | int/long | int64 | long | integer/string | Bignum | 
| uint32 | Uses variable-length encoding. | uint32 | int | int/long | uint32 | uint | integer | Bignum or Fixnum (as required) | 
| uint64 | Uses variable-length encoding. | uint64 | long | int/long | uint64 | ulong | integer/string | Bignum or Fixnum (as required) | 
| sint32 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int32s. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) | 
| sint64 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int64s. | int64 | long | int/long | int64 | long | integer/string | Bignum | 
| fixed32 | Always four bytes. More efficient than uint32 if values are often greater than 2^28. | uint32 | int | int | uint32 | uint | integer | Bignum or Fixnum (as required) | 
| fixed64 | Always eight bytes. More efficient than uint64 if values are often greater than 2^56. | uint64 | long | int/long | uint64 | ulong | integer/string | Bignum | 
| sfixed32 | Always four bytes. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) | 
| sfixed64 | Always eight bytes. | int64 | long | int/long | int64 | long | integer/string | Bignum | 
| bool | bool | boolean | boolean | bool | bool | boolean | TrueClass/FalseClass | |
| string | A string must always contain UTF-8 encoded or 7-bit ASCII text. | string | String | str/unicode | string | string | string | String (UTF-8) | 
| bytes | May contain any arbitrary sequence of bytes. | string | ByteString | str | []byte | ByteString | string | String (ASCII-8BIT) |