mirror of
https://github.com/safing/portmaster
synced 2025-09-01 18:19:12 +00:00
Add profile descriptions for all internal profiles and apply them with the metadata
This commit is contained in:
parent
7b77c6240a
commit
43fd265e45
1 changed files with 35 additions and 10 deletions
|
@ -11,49 +11,77 @@ const (
|
|||
UnidentifiedProfileID = "_unidentified"
|
||||
// UnidentifiedProfileName is the name used for unidentified processes.
|
||||
UnidentifiedProfileName = "Unidentified Processes"
|
||||
// UnidentifiedProfileDescription is the description used for unidentified processes.
|
||||
UnidentifiedProfileDescription = `This is not a real application, but a collection of connections that could not be attributed to a process. This could be because the Portmaster failed to identify the process, or simply because there is no process waiting for an incoming connection.
|
||||
|
||||
Seeing a lot of incoming connections here is normal, as this resembles the network chatter of other devices.
|
||||
`
|
||||
|
||||
// SystemProfileID is the profile ID used for the system/kernel.
|
||||
SystemProfileID = "_system"
|
||||
// SystemProfileName is the name used for the system/kernel.
|
||||
SystemProfileName = "Operating System"
|
||||
// SystemProfileDescription is the description used for the system/kernel.
|
||||
SystemProfileDescription = "This is the operation system itself."
|
||||
|
||||
// SystemResolverProfileID is the profile ID used for the system's DNS resolver.
|
||||
SystemResolverProfileID = "_system-resolver"
|
||||
// SystemResolverProfileName is the name used for the system's DNS resolver.
|
||||
SystemResolverProfileName = "System DNS Client"
|
||||
// SystemResolverProfileDescription is the description used for the system's DNS resolver.
|
||||
SystemResolverProfileDescription = `The System DNS Client is a system service that requires special handling. For regular network connections, the configured settings will apply as usual, but DNS requests coming from the System DNS Client are handled in a special way, as they could actually be coming from any other application on the system.
|
||||
|
||||
In order to respect the app settings of the actual application, DNS requests from the System DNS Client are only subject to the following settings:
|
||||
|
||||
- Outgoing Rules (without global rules)
|
||||
- Block Bypassing
|
||||
- Filter Lists
|
||||
`
|
||||
|
||||
// PortmasterProfileID is the profile ID used for the Portmaster Core itself.
|
||||
PortmasterProfileID = "_portmaster"
|
||||
// PortmasterProfileName is the name used for the Portmaster Core itself.
|
||||
PortmasterProfileName = "Portmaster Core Service"
|
||||
// PortmasterProfileDescription is the description used for the Portmaster Core itself.
|
||||
PortmasterProfileDescription = `This is the Portmaster itself, which runs in the background as a system service. App specific settings have no effect.`
|
||||
|
||||
// PortmasterAppProfileID is the profile ID used for the Portmaster App.
|
||||
PortmasterAppProfileID = "_portmaster-app"
|
||||
// PortmasterAppProfileName is the name used for the Portmaster App.
|
||||
PortmasterAppProfileName = "Portmaster User Interface"
|
||||
// PortmasterAppProfileDescription is the description used for the Portmaster App.
|
||||
PortmasterAppProfileDescription = `This is the Portmaster UI Windows.`
|
||||
|
||||
// PortmasterNotifierProfileID is the profile ID used for the Portmaster Notifier.
|
||||
PortmasterNotifierProfileID = "_portmaster-notifier"
|
||||
// PortmasterNotifierProfileName is the name used for the Portmaster Notifier.
|
||||
PortmasterNotifierProfileName = "Portmaster Notifier"
|
||||
// PortmasterNotifierProfileDescription is the description used for the Portmaster Notifier.
|
||||
PortmasterNotifierProfileDescription = `This is the Portmaster UI Tray Notifier.`
|
||||
)
|
||||
|
||||
func updateSpecialProfileMetadata(profile *Profile, binaryPath string) (ok, changed bool) {
|
||||
// Get new profile name and check if profile is applicable to special handling.
|
||||
var newProfileName string
|
||||
var newProfileName, newDescription string
|
||||
switch profile.ID {
|
||||
case UnidentifiedProfileID:
|
||||
newProfileName = UnidentifiedProfileName
|
||||
newDescription = UnidentifiedProfileDescription
|
||||
case SystemProfileID:
|
||||
newProfileName = SystemProfileName
|
||||
newDescription = SystemProfileDescription
|
||||
case SystemResolverProfileID:
|
||||
newProfileName = SystemResolverProfileName
|
||||
newDescription = SystemResolverProfileDescription
|
||||
case PortmasterProfileID:
|
||||
newProfileName = PortmasterProfileName
|
||||
newDescription = PortmasterProfileDescription
|
||||
case PortmasterAppProfileID:
|
||||
newProfileName = PortmasterAppProfileName
|
||||
newDescription = PortmasterAppProfileDescription
|
||||
case PortmasterNotifierProfileID:
|
||||
newProfileName = PortmasterNotifierProfileName
|
||||
newDescription = PortmasterNotifierProfileDescription
|
||||
default:
|
||||
return false, false
|
||||
}
|
||||
|
@ -64,6 +92,12 @@ func updateSpecialProfileMetadata(profile *Profile, binaryPath string) (ok, chan
|
|||
changed = true
|
||||
}
|
||||
|
||||
// Update description if needed.
|
||||
if profile.Description != newDescription {
|
||||
profile.Description = newDescription
|
||||
changed = true
|
||||
}
|
||||
|
||||
// Update LinkedPath to new value.
|
||||
if profile.LinkedPath != binaryPath {
|
||||
profile.LinkedPath = binaryPath
|
||||
|
@ -111,15 +145,6 @@ func getSpecialProfile(profileID, linkedPath string) *Profile {
|
|||
CfgOptionFilterListsKey: []string{},
|
||||
},
|
||||
)
|
||||
// Add description to tell users about the quirks of this profile.
|
||||
systemResolverProfile.Warning = `The System DNS Client is a system service that requires special handling. For regular network connections, the configured settings will apply as usual, but DNS requests coming from the System DNS Client are handled in a special way, as they could actually be coming from any other application on the system.
|
||||
|
||||
In order to respect the app settings of the actual application, DNS requests from the System DNS Client are only subject to the following settings:
|
||||
|
||||
- Outgoing Rules (without global rules)
|
||||
- Block Bypassing
|
||||
- Filter Lists
|
||||
`
|
||||
return systemResolverProfile
|
||||
|
||||
case PortmasterProfileID:
|
||||
|
|
Loading…
Add table
Reference in a new issue