mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 13:10:26 +08:00 
			
		
		
		
	
		
			
	
	
		
			99 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			99 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								package securitymanager
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import (
							 | 
						||
| 
								 | 
							
									"encoding/json"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAdmin/internal/rpc"
							 | 
						||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
							 | 
						||
| 
								 | 
							
									"github.com/iwind/TeaGo/logs"
							 | 
						||
| 
								 | 
							
									"reflect"
							 | 
						||
| 
								 | 
							
									"sync"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var locker sync.Mutex
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const (
							 | 
						||
| 
								 | 
							
									SecuritySettingName = "adminSecurityConfig"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									FrameNone       = ""
							 | 
						||
| 
								 | 
							
									FrameDeny       = "DENY"
							 | 
						||
| 
								 | 
							
									FrameSameOrigin = "SAMEORIGIN"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var sharedSecurityConfig *SecurityConfig = nil
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								type SecurityConfig struct {
							 | 
						||
| 
								 | 
							
									Frame string `json:"frame"`
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func LoadSecurityConfig() (*SecurityConfig, error) {
							 | 
						||
| 
								 | 
							
									locker.Lock()
							 | 
						||
| 
								 | 
							
									defer locker.Unlock()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									config, err := loadSecurityConfig()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return nil, err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									v := reflect.Indirect(reflect.ValueOf(config)).Interface().(SecurityConfig)
							 | 
						||
| 
								 | 
							
									return &v, nil
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func UpdateSecurityConfig(securityConfig *SecurityConfig) error {
							 | 
						||
| 
								 | 
							
									locker.Lock()
							 | 
						||
| 
								 | 
							
									defer locker.Unlock()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									var rpcClient, err = rpc.SharedRPC()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									valueJSON, err := json.Marshal(securityConfig)
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									_, err = rpcClient.SysSettingRPC().UpdateSysSetting(rpcClient.Context(1), &pb.UpdateSysSettingRequest{
							 | 
						||
| 
								 | 
							
										Code:      SecuritySettingName,
							 | 
						||
| 
								 | 
							
										ValueJSON: valueJSON,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									sharedSecurityConfig = securityConfig
							 | 
						||
| 
								 | 
							
									return nil
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func loadSecurityConfig() (*SecurityConfig, error) {
							 | 
						||
| 
								 | 
							
									if sharedSecurityConfig != nil {
							 | 
						||
| 
								 | 
							
										return sharedSecurityConfig, nil
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									var rpcClient, err = rpc.SharedRPC()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return nil, err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									resp, err := rpcClient.SysSettingRPC().ReadSysSetting(rpcClient.Context(1), &pb.ReadSysSettingRequest{
							 | 
						||
| 
								 | 
							
										Code: SecuritySettingName,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										return nil, err
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									if len(resp.ValueJSON) == 0 {
							 | 
						||
| 
								 | 
							
										sharedSecurityConfig = defaultSecurityConfig()
							 | 
						||
| 
								 | 
							
										return sharedSecurityConfig, nil
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									config := &SecurityConfig{}
							 | 
						||
| 
								 | 
							
									err = json.Unmarshal(resp.ValueJSON, config)
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										logs.Println("[SECURITY_MANAGER]" + err.Error())
							 | 
						||
| 
								 | 
							
										sharedSecurityConfig = defaultSecurityConfig()
							 | 
						||
| 
								 | 
							
										return sharedSecurityConfig, nil
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									sharedSecurityConfig = config
							 | 
						||
| 
								 | 
							
									return sharedSecurityConfig, nil
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func defaultSecurityConfig() *SecurityConfig {
							 | 
						||
| 
								 | 
							
									return &SecurityConfig{
							 | 
						||
| 
								 | 
							
										Frame: FrameSameOrigin,
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								}
							 |