Spaces:
Configuration error
Configuration error
package downloader | |
import ( | |
"encoding/json" | |
"errors" | |
"fmt" | |
"io" | |
"net/http" | |
"strings" | |
) | |
type HuggingFaceScanResult struct { | |
RepositoryId string `json:"repositoryId"` | |
Revision string `json:"revision"` | |
HasUnsafeFiles bool `json:"hasUnsafeFile"` | |
ClamAVInfectedFiles []string `json:"clamAVInfectedFiles"` | |
DangerousPickles []string `json:"dangerousPickles"` | |
ScansDone bool `json:"scansDone"` | |
} | |
var ErrNonHuggingFaceFile = errors.New("not a huggingface repo") | |
var ErrUnsafeFilesFound = errors.New("unsafe files found") | |
func HuggingFaceScan(uri URI) (*HuggingFaceScanResult, error) { | |
cleanParts := strings.Split(uri.ResolveURL(), "/") | |
if len(cleanParts) <= 4 || cleanParts[2] != "huggingface.co" { | |
return nil, ErrNonHuggingFaceFile | |
} | |
results, err := http.Get(fmt.Sprintf("https://huggingface.co/api/models/%s/%s/scan", cleanParts[3], cleanParts[4])) | |
if err != nil { | |
return nil, err | |
} | |
if results.StatusCode != 200 { | |
return nil, fmt.Errorf("unexpected status code during HuggingFaceScan: %d", results.StatusCode) | |
} | |
scanResult := &HuggingFaceScanResult{} | |
bodyBytes, err := io.ReadAll(results.Body) | |
if err != nil { | |
return nil, err | |
} | |
err = json.Unmarshal(bodyBytes, scanResult) | |
if err != nil { | |
return nil, err | |
} | |
if scanResult.HasUnsafeFiles { | |
return scanResult, ErrUnsafeFilesFound | |
} | |
return scanResult, nil | |
} | |