From 768646aa89013df636b211ddaeeda019d458cd76 Mon Sep 17 00:00:00 2001 From: fearful-symmetry Date: Tue, 5 Dec 2023 12:44:59 -0800 Subject: [PATCH] add APIs --- system.go | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/system.go b/system.go index 3d37e306..3b59dba2 100644 --- a/system.go +++ b/system.go @@ -52,6 +52,8 @@ func Host() (types.Host, error) { return provider.Host() } +// HostFS is the same as Host, but allows for a custom root hostfs mountpoint +// a custom filesystem root is only supported on linux, and this will fallback to the default provider on other platforms func HostFS(hostfs string) (types.Host, error) { provider := registry.GetHostProviderWithRoot(hostfs) if provider == nil { @@ -72,6 +74,16 @@ func Process(pid int) (types.Process, error) { return provider.Process(pid) } +// ProcessFS is the same as Process, but allows for a custom root hostfs mountpoint +// a custom filesystem root is only supported on linux, and this will fallback to the default provider on other platforms +func ProcessFS(hostfs string, pid int) (types.Process, error) { + provider := registry.GetProcessProviderWithRoot(hostfs) + if provider == nil { + return nil, types.ErrNotImplemented + } + return provider.Process(pid) +} + // Processes return a list of all processes. If process information collection // is not implemented for this platform then types.ErrNotImplemented is // returned. @@ -83,6 +95,16 @@ func Processes() ([]types.Process, error) { return provider.Processes() } +// ProcessesFS is the same as Processes, but allows for a custom root hostfs mountpoint +// a custom filesystem root is only supported on linux, and this will fallback to the default provider on other platforms +func ProcessesFS(hostfs string) ([]types.Process, error) { + provider := registry.GetProcessProviderWithRoot(hostfs) + if provider == nil { + return nil, types.ErrNotImplemented + } + return provider.Processes() +} + // Self return a types.Process object representing this process. If process // information collection is not implemented for this platform then // types.ErrNotImplemented is returned.