123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- package v1
- import (
- "fmt"
- "strings"
- "github.com/pkg/errors"
- "github.com/usememos/memos/internal/util"
- )
- const (
- WorkspaceSettingNamePrefix = "settings/"
- UserNamePrefix = "users/"
- MemoNamePrefix = "memos/"
- ResourceNamePrefix = "resources/"
- InboxNamePrefix = "inboxes/"
- IdentityProviderNamePrefix = "identityProviders/"
- ActivityNamePrefix = "activities/"
- )
- // GetNameParentTokens returns the tokens from a resource name.
- func GetNameParentTokens(name string, tokenPrefixes ...string) ([]string, error) {
- parts := strings.Split(name, "/")
- if len(parts) != 2*len(tokenPrefixes) {
- return nil, errors.Errorf("invalid request %q", name)
- }
- var tokens []string
- for i, tokenPrefix := range tokenPrefixes {
- if fmt.Sprintf("%s/", parts[2*i]) != tokenPrefix {
- return nil, errors.Errorf("invalid prefix %q in request %q", tokenPrefix, name)
- }
- if parts[2*i+1] == "" {
- return nil, errors.Errorf("invalid request %q with empty prefix %q", name, tokenPrefix)
- }
- tokens = append(tokens, parts[2*i+1])
- }
- return tokens, nil
- }
- func ExtractWorkspaceSettingKeyFromName(name string) (string, error) {
- tokens, err := GetNameParentTokens(name, WorkspaceSettingNamePrefix)
- if err != nil {
- return "", err
- }
- return tokens[0], nil
- }
- // ExtractUserIDFromName returns the uid from a resource name.
- func ExtractUserIDFromName(name string) (int32, error) {
- tokens, err := GetNameParentTokens(name, UserNamePrefix)
- if err != nil {
- return 0, err
- }
- id, err := util.ConvertStringToInt32(tokens[0])
- if err != nil {
- return 0, errors.Errorf("invalid user ID %q", tokens[0])
- }
- return id, nil
- }
- // ExtractMemoUIDFromName returns the memo UID from a resource name.
- // e.g., "memos/uuid" -> "uuid".
- func ExtractMemoUIDFromName(name string) (string, error) {
- tokens, err := GetNameParentTokens(name, MemoNamePrefix)
- if err != nil {
- return "", err
- }
- id := tokens[0]
- return id, nil
- }
- // ExtractResourceUIDFromName returns the resource UID from a resource name.
- func ExtractResourceUIDFromName(name string) (string, error) {
- tokens, err := GetNameParentTokens(name, ResourceNamePrefix)
- if err != nil {
- return "", err
- }
- id := tokens[0]
- return id, nil
- }
- // ExtractInboxIDFromName returns the inbox ID from a resource name.
- func ExtractInboxIDFromName(name string) (int32, error) {
- tokens, err := GetNameParentTokens(name, InboxNamePrefix)
- if err != nil {
- return 0, err
- }
- id, err := util.ConvertStringToInt32(tokens[0])
- if err != nil {
- return 0, errors.Errorf("invalid inbox ID %q", tokens[0])
- }
- return id, nil
- }
- func ExtractIdentityProviderIDFromName(name string) (int32, error) {
- tokens, err := GetNameParentTokens(name, IdentityProviderNamePrefix)
- if err != nil {
- return 0, err
- }
- id, err := util.ConvertStringToInt32(tokens[0])
- if err != nil {
- return 0, errors.Errorf("invalid identity provider ID %q", tokens[0])
- }
- return id, nil
- }
- func ExtractActivityIDFromName(name string) (int32, error) {
- tokens, err := GetNameParentTokens(name, ActivityNamePrefix)
- if err != nil {
- return 0, err
- }
- id, err := util.ConvertStringToInt32(tokens[0])
- if err != nil {
- return 0, errors.Errorf("invalid activity ID %q", tokens[0])
- }
- return id, nil
- }
|