mirror of
https://github.com/safing/portmaster
synced 2025-04-19 10:29:11 +00:00
* Move portbase into monorepo * Add new simple module mgr * [WIP] Switch to new simple module mgr * Add StateMgr and more worker variants * [WIP] Switch more modules * [WIP] Switch more modules * [WIP] swtich more modules * [WIP] switch all SPN modules * [WIP] switch all service modules * [WIP] Convert all workers to the new module system * [WIP] add new task system to module manager * [WIP] Add second take for scheduling workers * [WIP] Add FIXME for bugs in new scheduler * [WIP] Add minor improvements to scheduler * [WIP] Add new worker scheduler * [WIP] Fix more bug related to new module system * [WIP] Fix start handing of the new module system * [WIP] Improve startup process * [WIP] Fix minor issues * [WIP] Fix missing subsystem in settings * [WIP] Initialize managers in constructor * [WIP] Move module event initialization to constrictors * [WIP] Fix setting for enabling and disabling the SPN module * [WIP] Move API registeration into module construction * [WIP] Update states mgr for all modules * [WIP] Add CmdLine operation support * Add state helper methods to module group and instance * Add notification and module status handling to status package * Fix starting issues * Remove pilot widget and update security lock to new status data * Remove debug logs * Improve http server shutdown * Add workaround for cleanly shutting down firewall+netquery * Improve logging * Add syncing states with notifications for new module system * Improve starting, stopping, shutdown; resolve FIXMEs/TODOs * [WIP] Fix most unit tests * Review new module system and fix minor issues * Push shutdown and restart events again via API * Set sleep mode via interface * Update example/template module * [WIP] Fix spn/cabin unit test * Remove deprecated UI elements * Make log output more similar for the logging transition phase * Switch spn hub and observer cmds to new module system * Fix log sources * Make worker mgr less error prone * Fix tests and minor issues * Fix observation hub * Improve shutdown and restart handling * Split up big connection.go source file * Move varint and dsd packages to structures repo * Improve expansion test * Fix linter warnings * Fix interception module on windows * Fix linter errors --------- Co-authored-by: Vladimir Stoilov <vladimir@safing.io>
95 lines
2.5 KiB
Go
95 lines
2.5 KiB
Go
package process
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
"strconv"
|
|
|
|
"github.com/safing/portmaster/base/api"
|
|
"github.com/safing/portmaster/service/profile"
|
|
)
|
|
|
|
func registerAPIEndpoints() error {
|
|
if err := api.RegisterEndpoint(api.Endpoint{
|
|
Name: "Get Process Tag Metadata",
|
|
Description: "Get information about process tags.",
|
|
Path: "process/tags",
|
|
Read: api.PermitUser,
|
|
StructFunc: handleProcessTagMetadata,
|
|
}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := api.RegisterEndpoint(api.Endpoint{
|
|
Name: "Get Processes by Profile",
|
|
Description: "Get all recently active processes using the given profile",
|
|
Path: "process/list/by-profile/{source:[a-z]+}/{id:[A-z0-9-]+}",
|
|
Read: api.PermitUser,
|
|
StructFunc: handleGetProcessesByProfile,
|
|
}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := api.RegisterEndpoint(api.Endpoint{
|
|
Name: "Get Process Group Leader By PID",
|
|
Description: "Load a process group leader by a child PID",
|
|
Path: "process/group-leader/{pid:[0-9]+}",
|
|
Read: api.PermitUser,
|
|
StructFunc: handleGetProcessGroupLeader,
|
|
}); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func handleProcessTagMetadata(ar *api.Request) (i interface{}, err error) {
|
|
tagRegistryLock.Lock()
|
|
defer tagRegistryLock.Unlock()
|
|
|
|
// Create response struct.
|
|
resp := struct {
|
|
Tags []TagDescription
|
|
}{
|
|
Tags: make([]TagDescription, 0, len(tagRegistry)*2),
|
|
}
|
|
|
|
// Get all tag descriptions.
|
|
for _, th := range tagRegistry {
|
|
resp.Tags = append(resp.Tags, th.TagDescriptions()...)
|
|
}
|
|
|
|
return resp, nil
|
|
}
|
|
|
|
func handleGetProcessesByProfile(ar *api.Request) (any, error) {
|
|
source := ar.URLVars["source"]
|
|
id := ar.URLVars["id"]
|
|
if id == "" || source == "" {
|
|
return nil, api.ErrorWithStatus(errors.New("missing profile source/id"), http.StatusBadRequest)
|
|
}
|
|
|
|
result := GetProcessesWithProfile(ar.Context(), profile.ProfileSource(source), id, true)
|
|
return result, nil
|
|
}
|
|
|
|
func handleGetProcessGroupLeader(ar *api.Request) (any, error) {
|
|
pid, err := strconv.ParseInt(ar.URLVars["pid"], 10, 0)
|
|
if err != nil {
|
|
return nil, api.ErrorWithStatus(err, http.StatusBadRequest)
|
|
}
|
|
|
|
process, err := GetOrFindProcess(ar.Context(), int(pid))
|
|
if err != nil {
|
|
return nil, api.ErrorWithStatus(err, http.StatusInternalServerError)
|
|
}
|
|
err = process.FindProcessGroupLeader(ar.Context())
|
|
switch {
|
|
case process.Leader() != nil:
|
|
return process.Leader(), nil
|
|
case err != nil:
|
|
return nil, api.ErrorWithStatus(err, http.StatusInternalServerError)
|
|
default:
|
|
return nil, api.ErrorWithStatus(errors.New("leader not found"), http.StatusNotFound)
|
|
}
|
|
}
|