mirror of
https://github.com/larksuite/cli.git
synced 2026-07-03 14:02:43 +08:00
* feat: add FileIO extension for file transfer abstraction Introduce extension/fileio package with Provider/FileIO/File interfaces and a global registry, following the same pattern as extension/credential. - Add LocalFileIO default implementation with path validation and atomic writes - Wire FileIOProvider into Factory and resolve at runtime via RuntimeContext.FileIO() - Factory holds Provider (not resolved instance), deferring resolution to execution time
32 lines
807 B
Go
32 lines
807 B
Go
// Copyright (c) 2026 Lark Technologies Pte. Ltd.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package fileio
|
|
|
|
import "sync"
|
|
|
|
var (
|
|
mu sync.Mutex
|
|
provider Provider
|
|
)
|
|
|
|
// Register registers a FileIO Provider.
|
|
// Later registrations override earlier ones (last-write-wins).
|
|
// Unlike credential.Register which appends to a chain (multiple credential
|
|
// sources are tried in order), FileIO uses a single active provider because
|
|
// only one file I/O backend is active at a time (local vs server mode).
|
|
// Typically called from init() via blank import.
|
|
func Register(p Provider) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
provider = p
|
|
}
|
|
|
|
// GetProvider returns the currently registered Provider.
|
|
// Returns nil if no provider has been registered.
|
|
func GetProvider() Provider {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
return provider
|
|
}
|