Files
ragflow/internal/agent/sandbox/artifacts.go
Zhichang Yu e45659868a feat(agent): ship the Go agent canvas port — eino interrupt/resume + Redis check-pointing (#16035)
Replaces the Python agent canvas runtime with a Go implementation that
runs inside `cmd/server_main`.

The canvas compiles into an eino Workflow that pauses on wait-for-user
via native Interrupt/Resume (no sentinel flag) and resumes from a
Redis-backed CheckPointStore.

All 21 Python agent components and ~35 tools are ported with functional
parity.

Sandbox providers now read their JSON config from the admin-panel
system_settings table with env fallback.

234 files / +35,413 / -6,111. All Go files are gofmt-clean (CI gate
added); drops the v2 DSL E2E step and the gap-analysis plan (both
redundant after the port ships).

## Type of change

- [x] Refactoring
- [x] New feature
- [x] Bug fix

🤖 Generated with [Claude Code](https://claude.com/claude-code)

---------

Co-authored-by: Claude <noreply@anthropic.com>
2026-06-17 13:24:03 +08:00

48 lines
1.6 KiB
Go

//
// Copyright 2026 The InfiniFlow Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// artifacts.go holds the cross-provider allowlist of artifact
// extensions. LocalProvider and SSHProvider share this set so
// an artifact accepted by one is accepted by the other — the
// model sees a uniform `artifacts: [{name, content_b64,
// mime_type, size}, ...]` shape across providers.
//
// The set is ported verbatim from the Python side:
//
// agent/sandbox/providers/local.py (the _collect_artifacts
// allowlist)
// agent/sandbox/providers/ssh.py (ALLOWED_ARTIFACT_EXTENSIONS)
//
// Python's allowlist includes `.csv .html .jpeg .jpg .json .pdf
// .png .svg`. We mirror it 1:1. To extend, add here AND in
// both Python files.
package sandbox
// allowedArtifactExts is the set of file extensions the Local
// and SSH providers accept as code-execution artifacts. Anything
// outside this set is rejected at collect time.
var allowedArtifactExts = map[string]struct{}{
".csv": {},
".html": {},
".jpeg": {},
".jpg": {},
".json": {},
".pdf": {},
".png": {},
".svg": {},
}