{-# LANGUAGE ImplicitParams, RankNTypes, TypeApplications #-}


-- | Copyright  : Will Thompson and Iñaki García Etxebarria
-- License    : LGPL-2.1
-- Maintainer : Iñaki García Etxebarria
-- 
-- /No description available in the introspection data./

#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif

module GI.NM.Objects.VpnConnection
    ( 

-- * Exported types
    VpnConnection(..)                       ,
    IsVpnConnection                         ,
    toVpnConnection                         ,


 -- * Methods
-- | 
-- 
--  === __Click to display all available methods, including inherited ones__
-- ==== Methods
-- [bindProperty]("GI.GObject.Objects.Object#g:method:bindProperty"), [bindPropertyFull]("GI.GObject.Objects.Object#g:method:bindPropertyFull"), [forceFloating]("GI.GObject.Objects.Object#g:method:forceFloating"), [freezeNotify]("GI.GObject.Objects.Object#g:method:freezeNotify"), [getv]("GI.GObject.Objects.Object#g:method:getv"), [isFloating]("GI.GObject.Objects.Object#g:method:isFloating"), [notify]("GI.GObject.Objects.Object#g:method:notify"), [notifyByPspec]("GI.GObject.Objects.Object#g:method:notifyByPspec"), [ref]("GI.GObject.Objects.Object#g:method:ref"), [refSink]("GI.GObject.Objects.Object#g:method:refSink"), [runDispose]("GI.GObject.Objects.Object#g:method:runDispose"), [stealData]("GI.GObject.Objects.Object#g:method:stealData"), [stealQdata]("GI.GObject.Objects.Object#g:method:stealQdata"), [thawNotify]("GI.GObject.Objects.Object#g:method:thawNotify"), [unref]("GI.GObject.Objects.Object#g:method:unref"), [watchClosure]("GI.GObject.Objects.Object#g:method:watchClosure").
-- 
-- ==== Getters
-- [getBanner]("GI.NM.Objects.VpnConnection#g:method:getBanner"), [getClient]("GI.NM.Objects.Object#g:method:getClient"), [getConnection]("GI.NM.Objects.ActiveConnection#g:method:getConnection"), [getConnectionType]("GI.NM.Objects.ActiveConnection#g:method:getConnectionType"), [getController]("GI.NM.Objects.ActiveConnection#g:method:getController"), [getData]("GI.GObject.Objects.Object#g:method:getData"), [getDefault]("GI.NM.Objects.ActiveConnection#g:method:getDefault"), [getDefault6]("GI.NM.Objects.ActiveConnection#g:method:getDefault6"), [getDevices]("GI.NM.Objects.ActiveConnection#g:method:getDevices"), [getDhcp4Config]("GI.NM.Objects.ActiveConnection#g:method:getDhcp4Config"), [getDhcp6Config]("GI.NM.Objects.ActiveConnection#g:method:getDhcp6Config"), [getId]("GI.NM.Objects.ActiveConnection#g:method:getId"), [getIp4Config]("GI.NM.Objects.ActiveConnection#g:method:getIp4Config"), [getIp6Config]("GI.NM.Objects.ActiveConnection#g:method:getIp6Config"), [getMaster]("GI.NM.Objects.ActiveConnection#g:method:getMaster"), [getPath]("GI.NM.Objects.Object#g:method:getPath"), [getProperty]("GI.GObject.Objects.Object#g:method:getProperty"), [getQdata]("GI.GObject.Objects.Object#g:method:getQdata"), [getSpecificObjectPath]("GI.NM.Objects.ActiveConnection#g:method:getSpecificObjectPath"), [getState]("GI.NM.Objects.ActiveConnection#g:method:getState"), [getStateFlags]("GI.NM.Objects.ActiveConnection#g:method:getStateFlags"), [getStateReason]("GI.NM.Objects.ActiveConnection#g:method:getStateReason"), [getUuid]("GI.NM.Objects.ActiveConnection#g:method:getUuid"), [getVpn]("GI.NM.Objects.ActiveConnection#g:method:getVpn"), [getVpnState]("GI.NM.Objects.VpnConnection#g:method:getVpnState").
-- 
-- ==== Setters
-- [setData]("GI.GObject.Objects.Object#g:method:setData"), [setDataFull]("GI.GObject.Objects.Object#g:method:setDataFull"), [setProperty]("GI.GObject.Objects.Object#g:method:setProperty").

#if defined(ENABLE_OVERLOADING)
    ResolveVpnConnectionMethod              ,
#endif

-- ** getBanner #method:getBanner#

#if defined(ENABLE_OVERLOADING)
    VpnConnectionGetBannerMethodInfo        ,
#endif
    vpnConnectionGetBanner                  ,


-- ** getVpnState #method:getVpnState#

#if defined(ENABLE_OVERLOADING)
    VpnConnectionGetVpnStateMethodInfo      ,
#endif
    vpnConnectionGetVpnState                ,




 -- * Properties


-- ** banner #attr:banner#
-- | The VPN login banner of the active VPN connection.

#if defined(ENABLE_OVERLOADING)
    VpnConnectionBannerPropertyInfo         ,
#endif
    getVpnConnectionBanner                  ,
#if defined(ENABLE_OVERLOADING)
    vpnConnectionBanner                     ,
#endif


-- ** vpnState #attr:vpnState#
-- | The VPN state of the active VPN connection.

#if defined(ENABLE_OVERLOADING)
    VpnConnectionVpnStatePropertyInfo       ,
#endif
    getVpnConnectionVpnState                ,
#if defined(ENABLE_OVERLOADING)
    vpnConnectionVpnState                   ,
#endif




 -- * Signals


-- ** vpnStateChanged #signal:vpnStateChanged#

    VpnConnectionVpnStateChangedCallback    ,
#if defined(ENABLE_OVERLOADING)
    VpnConnectionVpnStateChangedSignalInfo  ,
#endif
    afterVpnConnectionVpnStateChanged       ,
    onVpnConnectionVpnStateChanged          ,




    ) where

import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P

import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.BasicTypes as B.Types
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GArray as B.GArray
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GHashTable as B.GHT
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GValue as B.GValue
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.GI.Base.Properties as B.Properties
import qualified Data.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
import qualified Data.Coerce as Coerce
import qualified Data.Text as T
import qualified Data.Kind as DK
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GHC.OverloadedLabels as OL
import qualified GHC.Records as R
import qualified Data.Word as DW
import qualified Data.Int as DI
import qualified System.Posix.Types as SPT
import qualified Foreign.C.Types as FCT

-- Workaround for https://gitlab.haskell.org/ghc/ghc/-/issues/23392
#if MIN_VERSION_base(4,18,0)
import qualified GI.GLib.Structs.Bytes as GLib.Bytes
import qualified GI.GLib.Structs.MainContext as GLib.MainContext
import qualified GI.GLib.Structs.VariantType as GLib.VariantType
import qualified GI.GObject.Objects.Object as GObject.Object
import qualified GI.Gio.Callbacks as Gio.Callbacks
import qualified GI.Gio.Interfaces.AsyncInitable as Gio.AsyncInitable
import qualified GI.Gio.Interfaces.AsyncResult as Gio.AsyncResult
import qualified GI.Gio.Interfaces.Initable as Gio.Initable
import qualified GI.Gio.Objects.Cancellable as Gio.Cancellable
import qualified GI.Gio.Objects.DBusConnection as Gio.DBusConnection
import qualified GI.NM.Callbacks as NM.Callbacks
import {-# SOURCE #-} qualified GI.NM.Enums as NM.Enums
import {-# SOURCE #-} qualified GI.NM.Flags as NM.Flags
import {-# SOURCE #-} qualified GI.NM.Interfaces.Connection as NM.Connection
import {-# SOURCE #-} qualified GI.NM.Objects.ActiveConnection as NM.ActiveConnection
import {-# SOURCE #-} qualified GI.NM.Objects.Checkpoint as NM.Checkpoint
import {-# SOURCE #-} qualified GI.NM.Objects.Client as NM.Client
import {-# SOURCE #-} qualified GI.NM.Objects.Device as NM.Device
import {-# SOURCE #-} qualified GI.NM.Objects.DhcpConfig as NM.DhcpConfig
import {-# SOURCE #-} qualified GI.NM.Objects.IPConfig as NM.IPConfig
import {-# SOURCE #-} qualified GI.NM.Objects.Object as NM.Object
import {-# SOURCE #-} qualified GI.NM.Objects.RemoteConnection as NM.RemoteConnection
import {-# SOURCE #-} qualified GI.NM.Objects.Setting as NM.Setting
import {-# SOURCE #-} qualified GI.NM.Objects.Setting8021x as NM.Setting8021x
import {-# SOURCE #-} qualified GI.NM.Objects.SettingAdsl as NM.SettingAdsl
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBluetooth as NM.SettingBluetooth
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBond as NM.SettingBond
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBridge as NM.SettingBridge
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBridgePort as NM.SettingBridgePort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingCdma as NM.SettingCdma
import {-# SOURCE #-} qualified GI.NM.Objects.SettingConnection as NM.SettingConnection
import {-# SOURCE #-} qualified GI.NM.Objects.SettingDcb as NM.SettingDcb
import {-# SOURCE #-} qualified GI.NM.Objects.SettingDummy as NM.SettingDummy
import {-# SOURCE #-} qualified GI.NM.Objects.SettingGeneric as NM.SettingGeneric
import {-# SOURCE #-} qualified GI.NM.Objects.SettingGsm as NM.SettingGsm
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIP4Config as NM.SettingIP4Config
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIP6Config as NM.SettingIP6Config
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIPConfig as NM.SettingIPConfig
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIPTunnel as NM.SettingIPTunnel
import {-# SOURCE #-} qualified GI.NM.Objects.SettingInfiniband as NM.SettingInfiniband
import {-# SOURCE #-} qualified GI.NM.Objects.SettingMacsec as NM.SettingMacsec
import {-# SOURCE #-} qualified GI.NM.Objects.SettingMacvlan as NM.SettingMacvlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOlpcMesh as NM.SettingOlpcMesh
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsBridge as NM.SettingOvsBridge
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsInterface as NM.SettingOvsInterface
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsPatch as NM.SettingOvsPatch
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsPort as NM.SettingOvsPort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingPpp as NM.SettingPpp
import {-# SOURCE #-} qualified GI.NM.Objects.SettingPppoe as NM.SettingPppoe
import {-# SOURCE #-} qualified GI.NM.Objects.SettingProxy as NM.SettingProxy
import {-# SOURCE #-} qualified GI.NM.Objects.SettingSerial as NM.SettingSerial
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTCConfig as NM.SettingTCConfig
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTeam as NM.SettingTeam
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTeamPort as NM.SettingTeamPort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTun as NM.SettingTun
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVlan as NM.SettingVlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVpn as NM.SettingVpn
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVxlan as NM.SettingVxlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWimax as NM.SettingWimax
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWired as NM.SettingWired
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWireless as NM.SettingWireless
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWirelessSecurity as NM.SettingWirelessSecurity
import {-# SOURCE #-} qualified GI.NM.Structs.BridgeVlan as NM.BridgeVlan
import {-# SOURCE #-} qualified GI.NM.Structs.DnsEntry as NM.DnsEntry
import {-# SOURCE #-} qualified GI.NM.Structs.IPAddress as NM.IPAddress
import {-# SOURCE #-} qualified GI.NM.Structs.IPRoute as NM.IPRoute
import {-# SOURCE #-} qualified GI.NM.Structs.IPRoutingRule as NM.IPRoutingRule
import {-# SOURCE #-} qualified GI.NM.Structs.LldpNeighbor as NM.LldpNeighbor
import {-# SOURCE #-} qualified GI.NM.Structs.Range as NM.Range
import {-# SOURCE #-} qualified GI.NM.Structs.TCAction as NM.TCAction
import {-# SOURCE #-} qualified GI.NM.Structs.TCQdisc as NM.TCQdisc
import {-# SOURCE #-} qualified GI.NM.Structs.TCTfilter as NM.TCTfilter
import {-# SOURCE #-} qualified GI.NM.Structs.TeamLinkWatcher as NM.TeamLinkWatcher
import {-# SOURCE #-} qualified GI.NM.Structs.VariantAttributeSpec as NM.VariantAttributeSpec

#else
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.NM.Enums as NM.Enums
import {-# SOURCE #-} qualified GI.NM.Objects.ActiveConnection as NM.ActiveConnection
import {-# SOURCE #-} qualified GI.NM.Objects.Object as NM.Object

#endif

-- | Memory-managed wrapper type.
newtype VpnConnection = VpnConnection (SP.ManagedPtr VpnConnection)
    deriving (VpnConnection -> VpnConnection -> Bool
(VpnConnection -> VpnConnection -> Bool)
-> (VpnConnection -> VpnConnection -> Bool) -> Eq VpnConnection
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: VpnConnection -> VpnConnection -> Bool
== :: VpnConnection -> VpnConnection -> Bool
$c/= :: VpnConnection -> VpnConnection -> Bool
/= :: VpnConnection -> VpnConnection -> Bool
Eq)

instance SP.ManagedPtrNewtype VpnConnection where
    toManagedPtr :: VpnConnection -> ManagedPtr VpnConnection
toManagedPtr (VpnConnection ManagedPtr VpnConnection
p) = ManagedPtr VpnConnection
p

foreign import ccall "nm_vpn_connection_get_type"
    c_nm_vpn_connection_get_type :: IO B.Types.GType

instance B.Types.TypedObject VpnConnection where
    glibType :: IO GType
glibType = IO GType
c_nm_vpn_connection_get_type

instance B.Types.GObject VpnConnection

-- | Type class for types which can be safely cast to t'VpnConnection', for instance with `toVpnConnection`.
class (SP.GObject o, O.IsDescendantOf VpnConnection o) => IsVpnConnection o
instance (SP.GObject o, O.IsDescendantOf VpnConnection o) => IsVpnConnection o

instance O.HasParentTypes VpnConnection
type instance O.ParentTypes VpnConnection = '[NM.ActiveConnection.ActiveConnection, NM.Object.Object, GObject.Object.Object]

-- | Cast to t'VpnConnection', for types for which this is known to be safe. For general casts, use 'Data.GI.Base.ManagedPtr.castTo'.
toVpnConnection :: (MIO.MonadIO m, IsVpnConnection o) => o -> m VpnConnection
toVpnConnection :: forall (m :: * -> *) o.
(MonadIO m, IsVpnConnection o) =>
o -> m VpnConnection
toVpnConnection = IO VpnConnection -> m VpnConnection
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO VpnConnection -> m VpnConnection)
-> (o -> IO VpnConnection) -> o -> m VpnConnection
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr VpnConnection -> VpnConnection)
-> o -> IO VpnConnection
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
 ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr VpnConnection -> VpnConnection
VpnConnection

-- | Convert t'VpnConnection' to and from t'Data.GI.Base.GValue.GValue'. See 'Data.GI.Base.GValue.toGValue' and 'Data.GI.Base.GValue.fromGValue'.
instance B.GValue.IsGValue (Maybe VpnConnection) where
    gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_nm_vpn_connection_get_type
    gvalueSet_ :: Ptr GValue -> Maybe VpnConnection -> IO ()
gvalueSet_ Ptr GValue
gv Maybe VpnConnection
P.Nothing = Ptr GValue -> Ptr VpnConnection -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr VpnConnection
forall a. Ptr a
FP.nullPtr :: FP.Ptr VpnConnection)
    gvalueSet_ Ptr GValue
gv (P.Just VpnConnection
obj) = VpnConnection -> (Ptr VpnConnection -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr VpnConnection
obj (Ptr GValue -> Ptr VpnConnection -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
    gvalueGet_ :: Ptr GValue -> IO (Maybe VpnConnection)
gvalueGet_ Ptr GValue
gv = do
        Ptr VpnConnection
ptr <- Ptr GValue -> IO (Ptr VpnConnection)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr VpnConnection)
        if Ptr VpnConnection
ptr Ptr VpnConnection -> Ptr VpnConnection -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr VpnConnection
forall a. Ptr a
FP.nullPtr
        then VpnConnection -> Maybe VpnConnection
forall a. a -> Maybe a
P.Just (VpnConnection -> Maybe VpnConnection)
-> IO VpnConnection -> IO (Maybe VpnConnection)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr VpnConnection -> VpnConnection)
-> Ptr VpnConnection -> IO VpnConnection
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr VpnConnection -> VpnConnection
VpnConnection Ptr VpnConnection
ptr
        else Maybe VpnConnection -> IO (Maybe VpnConnection)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe VpnConnection
forall a. Maybe a
P.Nothing
        
    

#if defined(ENABLE_OVERLOADING)
type family ResolveVpnConnectionMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
    ResolveVpnConnectionMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
    ResolveVpnConnectionMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
    ResolveVpnConnectionMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
    ResolveVpnConnectionMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
    ResolveVpnConnectionMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
    ResolveVpnConnectionMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
    ResolveVpnConnectionMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
    ResolveVpnConnectionMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
    ResolveVpnConnectionMethod "ref" o = GObject.Object.ObjectRefMethodInfo
    ResolveVpnConnectionMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
    ResolveVpnConnectionMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
    ResolveVpnConnectionMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
    ResolveVpnConnectionMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
    ResolveVpnConnectionMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
    ResolveVpnConnectionMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
    ResolveVpnConnectionMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
    ResolveVpnConnectionMethod "getBanner" o = VpnConnectionGetBannerMethodInfo
    ResolveVpnConnectionMethod "getClient" o = NM.Object.ObjectGetClientMethodInfo
    ResolveVpnConnectionMethod "getConnection" o = NM.ActiveConnection.ActiveConnectionGetConnectionMethodInfo
    ResolveVpnConnectionMethod "getConnectionType" o = NM.ActiveConnection.ActiveConnectionGetConnectionTypeMethodInfo
    ResolveVpnConnectionMethod "getController" o = NM.ActiveConnection.ActiveConnectionGetControllerMethodInfo
    ResolveVpnConnectionMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
    ResolveVpnConnectionMethod "getDefault" o = NM.ActiveConnection.ActiveConnectionGetDefaultMethodInfo
    ResolveVpnConnectionMethod "getDefault6" o = NM.ActiveConnection.ActiveConnectionGetDefault6MethodInfo
    ResolveVpnConnectionMethod "getDevices" o = NM.ActiveConnection.ActiveConnectionGetDevicesMethodInfo
    ResolveVpnConnectionMethod "getDhcp4Config" o = NM.ActiveConnection.ActiveConnectionGetDhcp4ConfigMethodInfo
    ResolveVpnConnectionMethod "getDhcp6Config" o = NM.ActiveConnection.ActiveConnectionGetDhcp6ConfigMethodInfo
    ResolveVpnConnectionMethod "getId" o = NM.ActiveConnection.ActiveConnectionGetIdMethodInfo
    ResolveVpnConnectionMethod "getIp4Config" o = NM.ActiveConnection.ActiveConnectionGetIp4ConfigMethodInfo
    ResolveVpnConnectionMethod "getIp6Config" o = NM.ActiveConnection.ActiveConnectionGetIp6ConfigMethodInfo
    ResolveVpnConnectionMethod "getMaster" o = NM.ActiveConnection.ActiveConnectionGetMasterMethodInfo
    ResolveVpnConnectionMethod "getPath" o = NM.Object.ObjectGetPathMethodInfo
    ResolveVpnConnectionMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
    ResolveVpnConnectionMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
    ResolveVpnConnectionMethod "getSpecificObjectPath" o = NM.ActiveConnection.ActiveConnectionGetSpecificObjectPathMethodInfo
    ResolveVpnConnectionMethod "getState" o = NM.ActiveConnection.ActiveConnectionGetStateMethodInfo
    ResolveVpnConnectionMethod "getStateFlags" o = NM.ActiveConnection.ActiveConnectionGetStateFlagsMethodInfo
    ResolveVpnConnectionMethod "getStateReason" o = NM.ActiveConnection.ActiveConnectionGetStateReasonMethodInfo
    ResolveVpnConnectionMethod "getUuid" o = NM.ActiveConnection.ActiveConnectionGetUuidMethodInfo
    ResolveVpnConnectionMethod "getVpn" o = NM.ActiveConnection.ActiveConnectionGetVpnMethodInfo
    ResolveVpnConnectionMethod "getVpnState" o = VpnConnectionGetVpnStateMethodInfo
    ResolveVpnConnectionMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
    ResolveVpnConnectionMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
    ResolveVpnConnectionMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
    ResolveVpnConnectionMethod l o = O.MethodResolutionFailed l o

instance (info ~ ResolveVpnConnectionMethod t VpnConnection, O.OverloadedMethod info VpnConnection p) => OL.IsLabel t (VpnConnection -> p) where
#if MIN_VERSION_base(4,10,0)
    fromLabel = O.overloadedMethod @info
#else
    fromLabel _ = O.overloadedMethod @info
#endif

#if MIN_VERSION_base(4,13,0)
instance (info ~ ResolveVpnConnectionMethod t VpnConnection, O.OverloadedMethod info VpnConnection p, R.HasField t VpnConnection p) => R.HasField t VpnConnection p where
    getField = O.overloadedMethod @info

#endif

instance (info ~ ResolveVpnConnectionMethod t VpnConnection, O.OverloadedMethodInfo info VpnConnection) => OL.IsLabel t (O.MethodProxy info VpnConnection) where
#if MIN_VERSION_base(4,10,0)
    fromLabel = O.MethodProxy
#else
    fromLabel _ = O.MethodProxy
#endif

#endif

-- signal VpnConnection::vpn-state-changed
-- | /No description available in the introspection data./
type VpnConnectionVpnStateChangedCallback =
    Word32
    -> Word32
    -> IO ()

type C_VpnConnectionVpnStateChangedCallback =
    Ptr VpnConnection ->                    -- object
    Word32 ->
    Word32 ->
    Ptr () ->                               -- user_data
    IO ()

-- | Generate a function pointer callable from C code, from a `C_VpnConnectionVpnStateChangedCallback`.
foreign import ccall "wrapper"
    mk_VpnConnectionVpnStateChangedCallback :: C_VpnConnectionVpnStateChangedCallback -> IO (FunPtr C_VpnConnectionVpnStateChangedCallback)

wrap_VpnConnectionVpnStateChangedCallback :: 
    GObject a => (a -> VpnConnectionVpnStateChangedCallback) ->
    C_VpnConnectionVpnStateChangedCallback
wrap_VpnConnectionVpnStateChangedCallback :: forall a.
GObject a =>
(a -> VpnConnectionVpnStateChangedCallback)
-> C_VpnConnectionVpnStateChangedCallback
wrap_VpnConnectionVpnStateChangedCallback a -> VpnConnectionVpnStateChangedCallback
gi'cb Ptr VpnConnection
gi'selfPtr Word32
object Word32
p0 Ptr ()
_ = do
    Ptr VpnConnection -> (VpnConnection -> IO ()) -> IO ()
forall o b.
(HasCallStack, GObject o) =>
Ptr o -> (o -> IO b) -> IO b
B.ManagedPtr.withNewObject Ptr VpnConnection
gi'selfPtr ((VpnConnection -> IO ()) -> IO ())
-> (VpnConnection -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \VpnConnection
gi'self -> a -> VpnConnectionVpnStateChangedCallback
gi'cb (VpnConnection -> a
forall a b. Coercible a b => a -> b
Coerce.coerce VpnConnection
gi'self)  Word32
object Word32
p0


-- | Connect a signal handler for the [vpnStateChanged](#signal:vpnStateChanged) signal, to be run before the default handler.
-- When <https://github.com/haskell-gi/haskell-gi/wiki/Overloading overloading> is enabled, this is equivalent to
-- 
-- @
-- 'Data.GI.Base.Signals.on' vpnConnection #vpnStateChanged callback
-- @
-- 
-- 
onVpnConnectionVpnStateChanged :: (IsVpnConnection a, MonadIO m) => a -> ((?self :: a) => VpnConnectionVpnStateChangedCallback) -> m SignalHandlerId
onVpnConnectionVpnStateChanged :: forall a (m :: * -> *).
(IsVpnConnection a, MonadIO m) =>
a
-> ((?self::a) => VpnConnectionVpnStateChangedCallback)
-> m SignalHandlerId
onVpnConnectionVpnStateChanged a
obj (?self::a) => VpnConnectionVpnStateChangedCallback
cb = IO SignalHandlerId -> m SignalHandlerId
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SignalHandlerId -> m SignalHandlerId)
-> IO SignalHandlerId -> m SignalHandlerId
forall a b. (a -> b) -> a -> b
$ do
    let wrapped :: a -> VpnConnectionVpnStateChangedCallback
wrapped a
self = let ?self = a
?self::a
self in (?self::a) => VpnConnectionVpnStateChangedCallback
VpnConnectionVpnStateChangedCallback
cb
    let wrapped' :: C_VpnConnectionVpnStateChangedCallback
wrapped' = (a -> VpnConnectionVpnStateChangedCallback)
-> C_VpnConnectionVpnStateChangedCallback
forall a.
GObject a =>
(a -> VpnConnectionVpnStateChangedCallback)
-> C_VpnConnectionVpnStateChangedCallback
wrap_VpnConnectionVpnStateChangedCallback a -> VpnConnectionVpnStateChangedCallback
wrapped
    FunPtr C_VpnConnectionVpnStateChangedCallback
wrapped'' <- C_VpnConnectionVpnStateChangedCallback
-> IO (FunPtr C_VpnConnectionVpnStateChangedCallback)
mk_VpnConnectionVpnStateChangedCallback C_VpnConnectionVpnStateChangedCallback
wrapped'
    a
-> Text
-> FunPtr C_VpnConnectionVpnStateChangedCallback
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"vpn-state-changed" FunPtr C_VpnConnectionVpnStateChangedCallback
wrapped'' SignalConnectMode
SignalConnectBefore Maybe Text
forall a. Maybe a
Nothing

-- | Connect a signal handler for the [vpnStateChanged](#signal:vpnStateChanged) signal, to be run after the default handler.
-- When <https://github.com/haskell-gi/haskell-gi/wiki/Overloading overloading> is enabled, this is equivalent to
-- 
-- @
-- 'Data.GI.Base.Signals.after' vpnConnection #vpnStateChanged callback
-- @
-- 
-- 
-- 
-- By default the object invoking the signal is not passed to the callback.
-- If you need to access it, you can use the implit @?self@ parameter.
-- Note that this requires activating the @ImplicitParams@ GHC extension.
-- 
afterVpnConnectionVpnStateChanged :: (IsVpnConnection a, MonadIO m) => a -> ((?self :: a) => VpnConnectionVpnStateChangedCallback) -> m SignalHandlerId
afterVpnConnectionVpnStateChanged :: forall a (m :: * -> *).
(IsVpnConnection a, MonadIO m) =>
a
-> ((?self::a) => VpnConnectionVpnStateChangedCallback)
-> m SignalHandlerId
afterVpnConnectionVpnStateChanged a
obj (?self::a) => VpnConnectionVpnStateChangedCallback
cb = IO SignalHandlerId -> m SignalHandlerId
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SignalHandlerId -> m SignalHandlerId)
-> IO SignalHandlerId -> m SignalHandlerId
forall a b. (a -> b) -> a -> b
$ do
    let wrapped :: a -> VpnConnectionVpnStateChangedCallback
wrapped a
self = let ?self = a
?self::a
self in (?self::a) => VpnConnectionVpnStateChangedCallback
VpnConnectionVpnStateChangedCallback
cb
    let wrapped' :: C_VpnConnectionVpnStateChangedCallback
wrapped' = (a -> VpnConnectionVpnStateChangedCallback)
-> C_VpnConnectionVpnStateChangedCallback
forall a.
GObject a =>
(a -> VpnConnectionVpnStateChangedCallback)
-> C_VpnConnectionVpnStateChangedCallback
wrap_VpnConnectionVpnStateChangedCallback a -> VpnConnectionVpnStateChangedCallback
wrapped
    FunPtr C_VpnConnectionVpnStateChangedCallback
wrapped'' <- C_VpnConnectionVpnStateChangedCallback
-> IO (FunPtr C_VpnConnectionVpnStateChangedCallback)
mk_VpnConnectionVpnStateChangedCallback C_VpnConnectionVpnStateChangedCallback
wrapped'
    a
-> Text
-> FunPtr C_VpnConnectionVpnStateChangedCallback
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"vpn-state-changed" FunPtr C_VpnConnectionVpnStateChangedCallback
wrapped'' SignalConnectMode
SignalConnectAfter Maybe Text
forall a. Maybe a
Nothing


#if defined(ENABLE_OVERLOADING)
data VpnConnectionVpnStateChangedSignalInfo
instance SignalInfo VpnConnectionVpnStateChangedSignalInfo where
    type HaskellCallbackType VpnConnectionVpnStateChangedSignalInfo = VpnConnectionVpnStateChangedCallback
    connectSignal obj cb connectMode detail = do
        let cb' = wrap_VpnConnectionVpnStateChangedCallback cb
        cb'' <- mk_VpnConnectionVpnStateChangedCallback cb'
        connectSignalFunPtr obj "vpn-state-changed" cb'' connectMode detail
    dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
        O.resolvedSymbolName = "GI.NM.Objects.VpnConnection::vpn-state-changed"
        , O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-VpnConnection.html#g:signal:vpnStateChanged"})

#endif

-- VVV Prop "banner"
   -- Type: TBasicType TUTF8
   -- Flags: [PropertyReadable]
   -- Nullable: (Just False,Nothing)

-- | Get the value of the “@banner@” property.
-- When <https://github.com/haskell-gi/haskell-gi/wiki/Overloading overloading> is enabled, this is equivalent to
-- 
-- @
-- 'Data.GI.Base.Attributes.get' vpnConnection #banner
-- @
getVpnConnectionBanner :: (MonadIO m, IsVpnConnection o) => o -> m T.Text
getVpnConnectionBanner :: forall (m :: * -> *) o.
(MonadIO m, IsVpnConnection o) =>
o -> m Text
getVpnConnectionBanner o
obj = IO Text -> m Text
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Text -> m Text) -> IO Text -> m Text
forall a b. (a -> b) -> a -> b
$ Text -> IO (Maybe Text) -> IO Text
forall a. HasCallStack => Text -> IO (Maybe a) -> IO a
checkUnexpectedNothing Text
"getVpnConnectionBanner" (IO (Maybe Text) -> IO Text) -> IO (Maybe Text) -> IO Text
forall a b. (a -> b) -> a -> b
$ o -> String -> IO (Maybe Text)
forall a. GObject a => a -> String -> IO (Maybe Text)
B.Properties.getObjectPropertyString o
obj String
"banner"

#if defined(ENABLE_OVERLOADING)
data VpnConnectionBannerPropertyInfo
instance AttrInfo VpnConnectionBannerPropertyInfo where
    type AttrAllowedOps VpnConnectionBannerPropertyInfo = '[ 'AttrGet, 'AttrClear]
    type AttrBaseTypeConstraint VpnConnectionBannerPropertyInfo = IsVpnConnection
    type AttrSetTypeConstraint VpnConnectionBannerPropertyInfo = (~) ()
    type AttrTransferTypeConstraint VpnConnectionBannerPropertyInfo = (~) ()
    type AttrTransferType VpnConnectionBannerPropertyInfo = ()
    type AttrGetType VpnConnectionBannerPropertyInfo = T.Text
    type AttrLabel VpnConnectionBannerPropertyInfo = "banner"
    type AttrOrigin VpnConnectionBannerPropertyInfo = VpnConnection
    attrGet = getVpnConnectionBanner
    attrSet = undefined
    attrTransfer _ = undefined
    attrConstruct = undefined
    attrClear = undefined
    dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
        O.resolvedSymbolName = "GI.NM.Objects.VpnConnection.banner"
        , O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-VpnConnection.html#g:attr:banner"
        })
#endif

-- VVV Prop "vpn-state"
   -- Type: TInterface (Name {namespace = "NM", name = "VpnConnectionState"})
   -- Flags: [PropertyReadable]
   -- Nullable: (Just False,Nothing)

-- | Get the value of the “@vpn-state@” property.
-- When <https://github.com/haskell-gi/haskell-gi/wiki/Overloading overloading> is enabled, this is equivalent to
-- 
-- @
-- 'Data.GI.Base.Attributes.get' vpnConnection #vpnState
-- @
getVpnConnectionVpnState :: (MonadIO m, IsVpnConnection o) => o -> m NM.Enums.VpnConnectionState
getVpnConnectionVpnState :: forall (m :: * -> *) o.
(MonadIO m, IsVpnConnection o) =>
o -> m VpnConnectionState
getVpnConnectionVpnState o
obj = IO VpnConnectionState -> m VpnConnectionState
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO VpnConnectionState -> m VpnConnectionState)
-> IO VpnConnectionState -> m VpnConnectionState
forall a b. (a -> b) -> a -> b
$ o -> String -> IO VpnConnectionState
forall a b. (GObject a, Enum b, BoxedEnum b) => a -> String -> IO b
B.Properties.getObjectPropertyEnum o
obj String
"vpn-state"

#if defined(ENABLE_OVERLOADING)
data VpnConnectionVpnStatePropertyInfo
instance AttrInfo VpnConnectionVpnStatePropertyInfo where
    type AttrAllowedOps VpnConnectionVpnStatePropertyInfo = '[ 'AttrGet]
    type AttrBaseTypeConstraint VpnConnectionVpnStatePropertyInfo = IsVpnConnection
    type AttrSetTypeConstraint VpnConnectionVpnStatePropertyInfo = (~) ()
    type AttrTransferTypeConstraint VpnConnectionVpnStatePropertyInfo = (~) ()
    type AttrTransferType VpnConnectionVpnStatePropertyInfo = ()
    type AttrGetType VpnConnectionVpnStatePropertyInfo = NM.Enums.VpnConnectionState
    type AttrLabel VpnConnectionVpnStatePropertyInfo = "vpn-state"
    type AttrOrigin VpnConnectionVpnStatePropertyInfo = VpnConnection
    attrGet = getVpnConnectionVpnState
    attrSet = undefined
    attrTransfer _ = undefined
    attrConstruct = undefined
    attrClear = undefined
    dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
        O.resolvedSymbolName = "GI.NM.Objects.VpnConnection.vpnState"
        , O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-VpnConnection.html#g:attr:vpnState"
        })
#endif

#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList VpnConnection
type instance O.AttributeList VpnConnection = VpnConnectionAttributeList
type VpnConnectionAttributeList = ('[ '("banner", VpnConnectionBannerPropertyInfo), '("client", NM.Object.ObjectClientPropertyInfo), '("connection", NM.ActiveConnection.ActiveConnectionConnectionPropertyInfo), '("controller", NM.ActiveConnection.ActiveConnectionControllerPropertyInfo), '("default", NM.ActiveConnection.ActiveConnectionDefaultPropertyInfo), '("default6", NM.ActiveConnection.ActiveConnectionDefault6PropertyInfo), '("devices", NM.ActiveConnection.ActiveConnectionDevicesPropertyInfo), '("dhcp4Config", NM.ActiveConnection.ActiveConnectionDhcp4ConfigPropertyInfo), '("dhcp6Config", NM.ActiveConnection.ActiveConnectionDhcp6ConfigPropertyInfo), '("id", NM.ActiveConnection.ActiveConnectionIdPropertyInfo), '("ip4Config", NM.ActiveConnection.ActiveConnectionIp4ConfigPropertyInfo), '("ip6Config", NM.ActiveConnection.ActiveConnectionIp6ConfigPropertyInfo), '("master", NM.ActiveConnection.ActiveConnectionMasterPropertyInfo), '("path", NM.Object.ObjectPathPropertyInfo), '("specificObjectPath", NM.ActiveConnection.ActiveConnectionSpecificObjectPathPropertyInfo), '("state", NM.ActiveConnection.ActiveConnectionStatePropertyInfo), '("stateFlags", NM.ActiveConnection.ActiveConnectionStateFlagsPropertyInfo), '("type", NM.ActiveConnection.ActiveConnectionTypePropertyInfo), '("uuid", NM.ActiveConnection.ActiveConnectionUuidPropertyInfo), '("vpn", NM.ActiveConnection.ActiveConnectionVpnPropertyInfo), '("vpnState", VpnConnectionVpnStatePropertyInfo)] :: [(Symbol, DK.Type)])
#endif

#if defined(ENABLE_OVERLOADING)
vpnConnectionBanner :: AttrLabelProxy "banner"
vpnConnectionBanner = AttrLabelProxy

vpnConnectionVpnState :: AttrLabelProxy "vpnState"
vpnConnectionVpnState = AttrLabelProxy

#endif

#if defined(ENABLE_OVERLOADING)
type instance O.SignalList VpnConnection = VpnConnectionSignalList
type VpnConnectionSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo), '("stateChanged", NM.ActiveConnection.ActiveConnectionStateChangedSignalInfo), '("vpnStateChanged", VpnConnectionVpnStateChangedSignalInfo)] :: [(Symbol, DK.Type)])

#endif

-- method VpnConnection::get_banner
-- method type : OrdinaryMethod
-- Args: [ Arg
--           { argCName = "vpn"
--           , argType =
--               TInterface Name { namespace = "NM" , name = "VpnConnection" }
--           , direction = DirectionIn
--           , mayBeNull = False
--           , argDoc =
--               Documentation
--                 { rawDocText = Just "a #NMVpnConnection" , sinceVersion = Nothing }
--           , argScope = ScopeTypeInvalid
--           , argClosure = -1
--           , argDestroy = -1
--           , argCallerAllocates = False
--           , argCallbackUserData = False
--           , transfer = TransferNothing
--           }
--       ]
-- Lengths: []
-- returnType: Just (TBasicType TUTF8)
-- throws : False
-- Skip return : False

foreign import ccall "nm_vpn_connection_get_banner" nm_vpn_connection_get_banner :: 
    Ptr VpnConnection ->                    -- vpn : TInterface (Name {namespace = "NM", name = "VpnConnection"})
    IO CString

-- | Gets the VPN login banner of the active t'GI.NM.Objects.VpnConnection.VpnConnection'.
vpnConnectionGetBanner ::
    (B.CallStack.HasCallStack, MonadIO m, IsVpnConnection a) =>
    a
    -- ^ /@vpn@/: a t'GI.NM.Objects.VpnConnection.VpnConnection'
    -> m T.Text
    -- ^ __Returns:__ the VPN login banner of the VPN connection. This is the internal
    -- string used by the connection, and must not be modified.
vpnConnectionGetBanner :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsVpnConnection a) =>
a -> m Text
vpnConnectionGetBanner a
vpn = IO Text -> m Text
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Text -> m Text) -> IO Text -> m Text
forall a b. (a -> b) -> a -> b
$ do
    Ptr VpnConnection
vpn' <- a -> IO (Ptr VpnConnection)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
vpn
    CString
result <- Ptr VpnConnection -> IO CString
nm_vpn_connection_get_banner Ptr VpnConnection
vpn'
    Text -> CString -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"vpnConnectionGetBanner" CString
result
    Text
result' <- HasCallStack => CString -> IO Text
CString -> IO Text
cstringToText CString
result
    a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
vpn
    Text -> IO Text
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Text
result'

#if defined(ENABLE_OVERLOADING)
data VpnConnectionGetBannerMethodInfo
instance (signature ~ (m T.Text), MonadIO m, IsVpnConnection a) => O.OverloadedMethod VpnConnectionGetBannerMethodInfo a signature where
    overloadedMethod = vpnConnectionGetBanner

instance O.OverloadedMethodInfo VpnConnectionGetBannerMethodInfo a where
    overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
        O.resolvedSymbolName = "GI.NM.Objects.VpnConnection.vpnConnectionGetBanner",
        O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-VpnConnection.html#v:vpnConnectionGetBanner"
        })


#endif

-- method VpnConnection::get_vpn_state
-- method type : OrdinaryMethod
-- Args: [ Arg
--           { argCName = "vpn"
--           , argType =
--               TInterface Name { namespace = "NM" , name = "VpnConnection" }
--           , direction = DirectionIn
--           , mayBeNull = False
--           , argDoc =
--               Documentation
--                 { rawDocText = Just "a #NMVpnConnection" , sinceVersion = Nothing }
--           , argScope = ScopeTypeInvalid
--           , argClosure = -1
--           , argDestroy = -1
--           , argCallerAllocates = False
--           , argCallbackUserData = False
--           , transfer = TransferNothing
--           }
--       ]
-- Lengths: []
-- returnType: Just
--               (TInterface
--                  Name { namespace = "NM" , name = "VpnConnectionState" })
-- throws : False
-- Skip return : False

foreign import ccall "nm_vpn_connection_get_vpn_state" nm_vpn_connection_get_vpn_state :: 
    Ptr VpnConnection ->                    -- vpn : TInterface (Name {namespace = "NM", name = "VpnConnection"})
    IO CUInt

-- | Gets the current t'GI.NM.Objects.VpnConnection.VpnConnection' state.
vpnConnectionGetVpnState ::
    (B.CallStack.HasCallStack, MonadIO m, IsVpnConnection a) =>
    a
    -- ^ /@vpn@/: a t'GI.NM.Objects.VpnConnection.VpnConnection'
    -> m NM.Enums.VpnConnectionState
    -- ^ __Returns:__ the VPN state of the active VPN connection.
vpnConnectionGetVpnState :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsVpnConnection a) =>
a -> m VpnConnectionState
vpnConnectionGetVpnState a
vpn = IO VpnConnectionState -> m VpnConnectionState
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO VpnConnectionState -> m VpnConnectionState)
-> IO VpnConnectionState -> m VpnConnectionState
forall a b. (a -> b) -> a -> b
$ do
    Ptr VpnConnection
vpn' <- a -> IO (Ptr VpnConnection)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
vpn
    CUInt
result <- Ptr VpnConnection -> IO CUInt
nm_vpn_connection_get_vpn_state Ptr VpnConnection
vpn'
    let result' :: VpnConnectionState
result' = (Int -> VpnConnectionState
forall a. Enum a => Int -> a
toEnum (Int -> VpnConnectionState)
-> (CUInt -> Int) -> CUInt -> VpnConnectionState
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CUInt -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral) CUInt
result
    a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
vpn
    VpnConnectionState -> IO VpnConnectionState
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return VpnConnectionState
result'

#if defined(ENABLE_OVERLOADING)
data VpnConnectionGetVpnStateMethodInfo
instance (signature ~ (m NM.Enums.VpnConnectionState), MonadIO m, IsVpnConnection a) => O.OverloadedMethod VpnConnectionGetVpnStateMethodInfo a signature where
    overloadedMethod = vpnConnectionGetVpnState

instance O.OverloadedMethodInfo VpnConnectionGetVpnStateMethodInfo a where
    overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
        O.resolvedSymbolName = "GI.NM.Objects.VpnConnection.vpnConnectionGetVpnState",
        O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-VpnConnection.html#v:vpnConnectionGetVpnState"
        })


#endif