diff --git a/pkg/process/doc.go b/pkg/process/doc.go new file mode 100644 index 00000000..7d59964a --- /dev/null +++ b/pkg/process/doc.go @@ -0,0 +1,17 @@ +// SPDX-License-Identifier: Apache-2.0 +// Copyright (C) 2024 The Falco Authors +// +// 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. + +// Package process provides the Process abstraction, allowing to define and interact with a new OS process. +package process diff --git a/pkg/process/process.go b/pkg/process/process.go new file mode 100644 index 00000000..f03c933c --- /dev/null +++ b/pkg/process/process.go @@ -0,0 +1,261 @@ +// SPDX-License-Identifier: Apache-2.0 +// Copyright (C) 2024 The Falco Authors +// +// 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. + +package process + +import ( + "context" + "errors" + "fmt" + "os" + "os/exec" + "path/filepath" + "regexp" + + "github.com/go-logr/logr" + "golang.org/x/sys/unix" + + "github.com/falcosecurity/event-generator/pkg/random" +) + +// Process represent an OS process. +type Process struct { + logger logr.Logger + // command is the command the process is associated with. + command string + // simExePath is the "simulated" executable path. This sets the executable path accessible through + // `readlink -f /proc/