#[repr(C)]pub struct NEFilterProviderConfiguration { /* private fields */ }
Expand description
The NEFilterProviderConfiguration class declares the programmatic interface of an object that configures a plugin-based content filter.
See also Apple’s documentation
Implementations§
Source§impl NEFilterProviderConfiguration
impl NEFilterProviderConfiguration
Sourcepub unsafe fn filterBrowsers(&self) -> bool
👎Deprecated: filterBrowsers is not supported on macOS
pub unsafe fn filterBrowsers(&self) -> bool
If YES, the filter plugin will be allowed to filter browser traffic. If NO, the filter plugin will not see any browser flows. Defaults to NO. At least one of filterBrowsers and filterSockets should be set to YES to make the filter take effect.
Sourcepub unsafe fn setFilterBrowsers(&self, filter_browsers: bool)
👎Deprecated: filterBrowsers is not supported on macOS
pub unsafe fn setFilterBrowsers(&self, filter_browsers: bool)
Setter for filterBrowsers
.
Sourcepub unsafe fn filterSockets(&self) -> bool
pub unsafe fn filterSockets(&self) -> bool
If YES, the filter plugin will be allowed to filter socket traffic. If NO, the filter plugin will not see any socket flows. Defaults to NO. At least one of filterBrowsers and filterSockets should be set to YES to make the filter take effect.
Sourcepub unsafe fn setFilterSockets(&self, filter_sockets: bool)
pub unsafe fn setFilterSockets(&self, filter_sockets: bool)
Setter for filterSockets
.
Sourcepub unsafe fn filterPackets(&self) -> bool
pub unsafe fn filterPackets(&self) -> bool
If YES, a NEFilterPacketProvider will be instantiated and will be allowed to filter packets.
Sourcepub unsafe fn setFilterPackets(&self, filter_packets: bool)
pub unsafe fn setFilterPackets(&self, filter_packets: bool)
Setter for filterPackets
.
Sourcepub unsafe fn vendorConfiguration(
&self,
) -> Option<Retained<NSDictionary<NSString, AnyObject>>>
pub unsafe fn vendorConfiguration( &self, ) -> Option<Retained<NSDictionary<NSString, AnyObject>>>
An optional dictionary of plugin-specific keys to be passed to the plugin.
Sourcepub unsafe fn setVendorConfiguration(
&self,
vendor_configuration: Option<&NSDictionary<NSString, AnyObject>>,
)
pub unsafe fn setVendorConfiguration( &self, vendor_configuration: Option<&NSDictionary<NSString, AnyObject>>, )
Setter for vendorConfiguration
.
Sourcepub unsafe fn serverAddress(&self) -> Option<Retained<NSString>>
pub unsafe fn serverAddress(&self) -> Option<Retained<NSString>>
The optional address of the server used to support the filter.
Sourcepub unsafe fn setServerAddress(&self, server_address: Option<&NSString>)
pub unsafe fn setServerAddress(&self, server_address: Option<&NSString>)
Setter for serverAddress
.
Sourcepub unsafe fn username(&self) -> Option<Retained<NSString>>
pub unsafe fn username(&self) -> Option<Retained<NSString>>
The optional username associated with the filter.
Sourcepub unsafe fn setUsername(&self, username: Option<&NSString>)
pub unsafe fn setUsername(&self, username: Option<&NSString>)
Setter for username
.
Sourcepub unsafe fn organization(&self) -> Option<Retained<NSString>>
pub unsafe fn organization(&self) -> Option<Retained<NSString>>
The optional organization associated with the filter.
Sourcepub unsafe fn setOrganization(&self, organization: Option<&NSString>)
pub unsafe fn setOrganization(&self, organization: Option<&NSString>)
Setter for organization
.
Sourcepub unsafe fn passwordReference(&self) -> Option<Retained<NSData>>
pub unsafe fn passwordReference(&self) -> Option<Retained<NSData>>
The optional password keychain reference associated with the filter.
Sourcepub unsafe fn setPasswordReference(&self, password_reference: Option<&NSData>)
pub unsafe fn setPasswordReference(&self, password_reference: Option<&NSData>)
Setter for passwordReference
.
Sourcepub unsafe fn identityReference(&self) -> Option<Retained<NSData>>
pub unsafe fn identityReference(&self) -> Option<Retained<NSData>>
The optional certificate identity keychain reference associated with the filter.
Sourcepub unsafe fn setIdentityReference(&self, identity_reference: Option<&NSData>)
pub unsafe fn setIdentityReference(&self, identity_reference: Option<&NSData>)
Setter for identityReference
.
Sourcepub unsafe fn filterDataProviderBundleIdentifier(
&self,
) -> Option<Retained<NSString>>
pub unsafe fn filterDataProviderBundleIdentifier( &self, ) -> Option<Retained<NSString>>
A string containing the bundle identifier of the NEFilterDataProvider app extension or system extension. If this property is nil, then the bundle identifier of the NEFilterDataProvider extension in the calling app’s bundle is used, and if the calling app’s bundle contains more than one NEFilterDataProvider extension then which one will be used is undefined.
Sourcepub unsafe fn setFilterDataProviderBundleIdentifier(
&self,
filter_data_provider_bundle_identifier: Option<&NSString>,
)
pub unsafe fn setFilterDataProviderBundleIdentifier( &self, filter_data_provider_bundle_identifier: Option<&NSString>, )
Setter for filterDataProviderBundleIdentifier
.
Sourcepub unsafe fn filterPacketProviderBundleIdentifier(
&self,
) -> Option<Retained<NSString>>
pub unsafe fn filterPacketProviderBundleIdentifier( &self, ) -> Option<Retained<NSString>>
A string containing the bundle identifier of the NEFilterPacketProvider app extension or system extension. If this property is nil, then the bundle identifier of the NEFilterPacketProvider extension in the calling app’s bundle is used, and if the calling app’s bundle contains more than one NEFilterPacketProvider extension then which one will be used is undefined.
Sourcepub unsafe fn setFilterPacketProviderBundleIdentifier(
&self,
filter_packet_provider_bundle_identifier: Option<&NSString>,
)
pub unsafe fn setFilterPacketProviderBundleIdentifier( &self, filter_packet_provider_bundle_identifier: Option<&NSString>, )
Setter for filterPacketProviderBundleIdentifier
.
Methods from Deref<Target = NSObject>§
Sourcepub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
pub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
Handle messages the object doesn’t recognize.
See Apple’s documentation for details.
Methods from Deref<Target = AnyObject>§
Sourcepub fn class(&self) -> &'static AnyClass
pub fn class(&self) -> &'static AnyClass
Dynamically find the class of this object.
§Panics
May panic if the object is invalid (which may be the case for objects
returned from unavailable init
/new
methods).
§Example
Check that an instance of NSObject
has the precise class NSObject
.
use objc2::ClassType;
use objc2::runtime::NSObject;
let obj = NSObject::new();
assert_eq!(obj.class(), NSObject::class());
Sourcepub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
👎Deprecated: this is difficult to use correctly, use Ivar::load
instead.
pub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
Ivar::load
instead.Use Ivar::load
instead.
§Safety
The object must have an instance variable with the given name, and it
must be of type T
.
See Ivar::load_ptr
for details surrounding this.
Sourcepub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
pub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
Attempt to downcast the object to a class of type T
.
This is the reference-variant. Use Retained::downcast
if you want
to convert a retained object to another type.
§Mutable classes
Some classes have immutable and mutable variants, such as NSString
and NSMutableString
.
When some Objective-C API signature says it gives you an immutable class, it generally expects you to not mutate that, even though it may technically be mutable “under the hood”.
So using this method to convert a NSString
to a NSMutableString
,
while not unsound, is generally frowned upon unless you created the
string yourself, or the API explicitly documents the string to be
mutable.
See Apple’s documentation on mutability and on
isKindOfClass:
for more details.
§Generic classes
Objective-C generics are called “lightweight generics”, and that’s because they aren’t exposed in the runtime. This makes it impossible to safely downcast to generic collections, so this is disallowed by this method.
You can, however, safely downcast to generic collections where all the
type-parameters are AnyObject
.
§Panics
This works internally by calling isKindOfClass:
. That means that the
object must have the instance method of that name, and an exception
will be thrown (if CoreFoundation is linked) or the process will abort
if that is not the case. In the vast majority of cases, you don’t need
to worry about this, since both root objects NSObject
and
NSProxy
implement this method.
§Examples
Cast an NSString
back and forth from NSObject
.
use objc2::rc::Retained;
use objc2_foundation::{NSObject, NSString};
let obj: Retained<NSObject> = NSString::new().into_super();
let string = obj.downcast_ref::<NSString>().unwrap();
// Or with `downcast`, if we do not need the object afterwards
let string = obj.downcast::<NSString>().unwrap();
Try (and fail) to cast an NSObject
to an NSString
.
use objc2_foundation::{NSObject, NSString};
let obj = NSObject::new();
assert!(obj.downcast_ref::<NSString>().is_none());
Try to cast to an array of strings.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
// This is invalid and doesn't type check.
let arr = arr.downcast_ref::<NSArray<NSString>>();
This fails to compile, since it would require enumerating over the array to ensure that each element is of the desired type, which is a performance pitfall.
Downcast when processing each element instead.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
for elem in arr {
if let Some(data) = elem.downcast_ref::<NSString>() {
// handle `data`
}
}
Trait Implementations§
Source§impl ClassType for NEFilterProviderConfiguration
impl ClassType for NEFilterProviderConfiguration
Source§const NAME: &'static str = "NEFilterProviderConfiguration"
const NAME: &'static str = "NEFilterProviderConfiguration"
Source§type ThreadKind = <<NEFilterProviderConfiguration as ClassType>::Super as ClassType>::ThreadKind
type ThreadKind = <<NEFilterProviderConfiguration as ClassType>::Super as ClassType>::ThreadKind
Source§impl CopyingHelper for NEFilterProviderConfiguration
impl CopyingHelper for NEFilterProviderConfiguration
Source§type Result = NEFilterProviderConfiguration
type Result = NEFilterProviderConfiguration
Self
if the type has no
immutable counterpart. Read moreSource§impl Hash for NEFilterProviderConfiguration
impl Hash for NEFilterProviderConfiguration
Source§impl NSCopying for NEFilterProviderConfiguration
impl NSCopying for NEFilterProviderConfiguration
Source§impl NSObjectProtocol for NEFilterProviderConfiguration
impl NSObjectProtocol for NEFilterProviderConfiguration
Source§fn isEqual(&self, other: Option<&AnyObject>) -> bool
fn isEqual(&self, other: Option<&AnyObject>) -> bool
Source§fn hash(&self) -> usize
fn hash(&self) -> usize
Source§fn isKindOfClass(&self, cls: &AnyClass) -> bool
fn isKindOfClass(&self, cls: &AnyClass) -> bool
Source§fn is_kind_of<T>(&self) -> bool
fn is_kind_of<T>(&self) -> bool
isKindOfClass
directly, or cast your objects with AnyObject::downcast_ref