mirror of
				https://github.com/usememos/memos.git
				synced 2025-10-25 05:46:03 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			40 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package v1
 | |
| 
 | |
| var authenticationAllowlistMethods = map[string]bool{
 | |
| 	"/memos.api.v1.WorkspaceService/GetWorkspaceProfile":          true,
 | |
| 	"/memos.api.v1.WorkspaceSettingService/GetWorkspaceSetting":   true,
 | |
| 	"/memos.api.v1.WorkspaceSettingService/ListWorkspaceSettings": true,
 | |
| 	"/memos.api.v1.IdentityProviderService/GetIdentityProvider":   true,
 | |
| 	"/memos.api.v1.IdentityProviderService/ListIdentityProviders": true,
 | |
| 	"/memos.api.v1.AuthService/GetAuthStatus":                     true,
 | |
| 	"/memos.api.v1.AuthService/SignIn":                            true,
 | |
| 	"/memos.api.v1.AuthService/SignInWithSSO":                     true,
 | |
| 	"/memos.api.v1.AuthService/SignOut":                           true,
 | |
| 	"/memos.api.v1.AuthService/SignUp":                            true,
 | |
| 	"/memos.api.v1.UserService/GetUser":                           true,
 | |
| 	"/memos.api.v1.UserService/GetUserAvatarBinary":               true,
 | |
| 	"/memos.api.v1.UserService/SearchUsers":                       true,
 | |
| 	"/memos.api.v1.MemoService/GetMemo":                           true,
 | |
| 	"/memos.api.v1.MemoService/GetMemoByUid":                      true,
 | |
| 	"/memos.api.v1.MemoService/ListMemos":                         true,
 | |
| 	"/memos.api.v1.MemoService/ListMemoTags":                      true,
 | |
| 	"/memos.api.v1.MemoService/SearchMemos":                       true,
 | |
| 	"/memos.api.v1.MarkdownService/GetLinkMetadata":               true,
 | |
| 	"/memos.api.v1.ResourceService/GetResourceBinary":             true,
 | |
| 	"/memos.api.v1.ResourceService/GetResourceByUid":              true,
 | |
| }
 | |
| 
 | |
| // isUnauthorizeAllowedMethod returns whether the method is exempted from authentication.
 | |
| func isUnauthorizeAllowedMethod(fullMethodName string) bool {
 | |
| 	return authenticationAllowlistMethods[fullMethodName]
 | |
| }
 | |
| 
 | |
| var allowedMethodsOnlyForAdmin = map[string]bool{
 | |
| 	"/memos.api.v1.UserService/CreateUser":                      true,
 | |
| 	"/memos.api.v1.WorkspaceSettingService/SetWorkspaceSetting": true,
 | |
| }
 | |
| 
 | |
| // isOnlyForAdminAllowedMethod returns true if the method is allowed to be called only by admin.
 | |
| func isOnlyForAdminAllowedMethod(methodName string) bool {
 | |
| 	return allowedMethodsOnlyForAdmin[methodName]
 | |
| }
 |