mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	增加ip2region库管理
This commit is contained in:
		
							
								
								
									
										60
									
								
								internal/rpc/services/service_file_chunk.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								internal/rpc/services/service_file_chunk.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,60 @@
 | 
			
		||||
package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"github.com/TeaOSLab/EdgeAPI/internal/db/models"
 | 
			
		||||
	rpcutils "github.com/TeaOSLab/EdgeAPI/internal/rpc/utils"
 | 
			
		||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// 文件片段相关服务
 | 
			
		||||
type FileChunkService struct {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 创建文件片段
 | 
			
		||||
func (this *FileChunkService) CreateFileChunk(ctx context.Context, req *pb.CreateFileChunkRequest) (*pb.CreateFileChunkResponse, error) {
 | 
			
		||||
	// 校验请求
 | 
			
		||||
	_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	chunkId, err := models.SharedFileChunkDAO.CreateFileChunk(req.FileId, req.Data)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.CreateFileChunkResponse{FileChunkId: chunkId}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获取的一个文件的所有片段IDs
 | 
			
		||||
func (this *FileChunkService) FindAllFileChunkIds(ctx context.Context, req *pb.FindAllFileChunkIdsRequest) (*pb.FindAllFileChunkIdsResponse, error) {
 | 
			
		||||
	// 校验请求
 | 
			
		||||
	_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeNode, rpcutils.UserTypeAdmin)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	chunkIds, err := models.SharedFileChunkDAO.FindAllFileChunkIds(req.FileId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.FindAllFileChunkIdsResponse{FileChunkIds: chunkIds}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 下载文件片段
 | 
			
		||||
func (this *FileChunkService) DownloadFileChunk(ctx context.Context, req *pb.DownloadFileChunkRequest) (*pb.DownloadFileChunkResponse, error) {
 | 
			
		||||
	// 校验请求
 | 
			
		||||
	_, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeNode, rpcutils.UserTypeAdmin)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	chunk, err := models.SharedFileChunkDAO.FindFileChunk(req.FileChunkId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if chunk == nil {
 | 
			
		||||
		return &pb.DownloadFileChunkResponse{FileChunk: nil}, nil
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.DownloadFileChunkResponse{FileChunk: &pb.FileChunk{Data: []byte(chunk.Data)}}, nil
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user