module GI.Ggit.Objects.CredSshKeyFromAgent
(
CredSshKeyFromAgent(..) ,
IsCredSshKeyFromAgent ,
toCredSshKeyFromAgent ,
noCredSshKeyFromAgent ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
CredSshKeyFromAgentGetUsernameMethodInfo,
#endif
credSshKeyFromAgentGetUsername ,
credSshKeyFromAgentNew ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
CredSshKeyFromAgentUsernamePropertyInfo ,
#endif
constructCredSshKeyFromAgentUsername ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
credSshKeyFromAgentUsername ,
#endif
getCredSshKeyFromAgentUsername ,
) 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.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GI.GObject.Objects.Object as GObject.Object
import qualified GI.Ggit.Objects.Cred as Ggit.Cred
import qualified GI.Ggit.Objects.Native as Ggit.Native
import qualified GI.Ggit.Objects.ObjectFactoryBase as Ggit.ObjectFactoryBase
import qualified GI.Gio.Interfaces.Initable as Gio.Initable
newtype CredSshKeyFromAgent = CredSshKeyFromAgent (ManagedPtr CredSshKeyFromAgent)
foreign import ccall "ggit_cred_ssh_key_from_agent_get_type"
c_ggit_cred_ssh_key_from_agent_get_type :: IO GType
instance GObject CredSshKeyFromAgent where
gobjectType _ = c_ggit_cred_ssh_key_from_agent_get_type
class GObject o => IsCredSshKeyFromAgent o
#if MIN_VERSION_base(4,9,0)
instance (GObject a, O.UnknownAncestorError CredSshKeyFromAgent a) =>
IsCredSshKeyFromAgent a
#endif
instance IsCredSshKeyFromAgent CredSshKeyFromAgent
instance Ggit.Cred.IsCred CredSshKeyFromAgent
instance Ggit.Native.IsNative CredSshKeyFromAgent
instance Ggit.ObjectFactoryBase.IsObjectFactoryBase CredSshKeyFromAgent
instance GObject.Object.IsObject CredSshKeyFromAgent
instance Gio.Initable.IsInitable CredSshKeyFromAgent
toCredSshKeyFromAgent :: (MonadIO m, IsCredSshKeyFromAgent o) => o -> m CredSshKeyFromAgent
toCredSshKeyFromAgent = liftIO . unsafeCastTo CredSshKeyFromAgent
noCredSshKeyFromAgent :: Maybe CredSshKeyFromAgent
noCredSshKeyFromAgent = Nothing
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
type family ResolveCredSshKeyFromAgentMethod (t :: Symbol) (o :: *) :: * where
ResolveCredSshKeyFromAgentMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveCredSshKeyFromAgentMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveCredSshKeyFromAgentMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveCredSshKeyFromAgentMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveCredSshKeyFromAgentMethod "init" o = Gio.Initable.InitableInitMethodInfo
ResolveCredSshKeyFromAgentMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveCredSshKeyFromAgentMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveCredSshKeyFromAgentMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveCredSshKeyFromAgentMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveCredSshKeyFromAgentMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveCredSshKeyFromAgentMethod "replaceData" o = GObject.Object.ObjectReplaceDataMethodInfo
ResolveCredSshKeyFromAgentMethod "replaceQdata" o = GObject.Object.ObjectReplaceQdataMethodInfo
ResolveCredSshKeyFromAgentMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveCredSshKeyFromAgentMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveCredSshKeyFromAgentMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveCredSshKeyFromAgentMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveCredSshKeyFromAgentMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveCredSshKeyFromAgentMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveCredSshKeyFromAgentMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveCredSshKeyFromAgentMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveCredSshKeyFromAgentMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveCredSshKeyFromAgentMethod "getUsername" o = CredSshKeyFromAgentGetUsernameMethodInfo
ResolveCredSshKeyFromAgentMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveCredSshKeyFromAgentMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveCredSshKeyFromAgentMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveCredSshKeyFromAgentMethod t CredSshKeyFromAgent, O.MethodInfo info CredSshKeyFromAgent p) => O.IsLabelProxy t (CredSshKeyFromAgent -> p) where
fromLabelProxy _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#if MIN_VERSION_base(4,9,0)
instance (info ~ ResolveCredSshKeyFromAgentMethod t CredSshKeyFromAgent, O.MethodInfo info CredSshKeyFromAgent p) => O.IsLabel t (CredSshKeyFromAgent -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#else
fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
#endif
#endif
getCredSshKeyFromAgentUsername :: (MonadIO m, IsCredSshKeyFromAgent o) => o -> m T.Text
getCredSshKeyFromAgentUsername obj = liftIO $ checkUnexpectedNothing "getCredSshKeyFromAgentUsername" $ getObjectPropertyString obj "username"
constructCredSshKeyFromAgentUsername :: (IsCredSshKeyFromAgent o) => T.Text -> IO (GValueConstruct o)
constructCredSshKeyFromAgentUsername val = constructObjectPropertyString "username" (Just val)
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data CredSshKeyFromAgentUsernamePropertyInfo
instance AttrInfo CredSshKeyFromAgentUsernamePropertyInfo where
type AttrAllowedOps CredSshKeyFromAgentUsernamePropertyInfo = '[ 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint CredSshKeyFromAgentUsernamePropertyInfo = (~) T.Text
type AttrBaseTypeConstraint CredSshKeyFromAgentUsernamePropertyInfo = IsCredSshKeyFromAgent
type AttrGetType CredSshKeyFromAgentUsernamePropertyInfo = T.Text
type AttrLabel CredSshKeyFromAgentUsernamePropertyInfo = "username"
type AttrOrigin CredSshKeyFromAgentUsernamePropertyInfo = CredSshKeyFromAgent
attrGet _ = getCredSshKeyFromAgentUsername
attrSet _ = undefined
attrConstruct _ = constructCredSshKeyFromAgentUsername
attrClear _ = undefined
#endif
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
instance O.HasAttributeList CredSshKeyFromAgent
type instance O.AttributeList CredSshKeyFromAgent = CredSshKeyFromAgentAttributeList
type CredSshKeyFromAgentAttributeList = ('[ '("native", Ggit.Native.NativeNativePropertyInfo), '("username", CredSshKeyFromAgentUsernamePropertyInfo)] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
credSshKeyFromAgentUsername :: AttrLabelProxy "username"
credSshKeyFromAgentUsername = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
type instance O.SignalList CredSshKeyFromAgent = CredSshKeyFromAgentSignalList
type CredSshKeyFromAgentSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "ggit_cred_ssh_key_from_agent_new" ggit_cred_ssh_key_from_agent_new ::
CString ->
Ptr (Ptr GError) ->
IO (Ptr CredSshKeyFromAgent)
credSshKeyFromAgentNew ::
(B.CallStack.HasCallStack, MonadIO m) =>
T.Text
-> m CredSshKeyFromAgent
credSshKeyFromAgentNew username = liftIO $ do
username' <- textToCString username
onException (do
result <- propagateGError $ ggit_cred_ssh_key_from_agent_new username'
checkUnexpectedReturnNULL "credSshKeyFromAgentNew" result
result' <- (wrapObject CredSshKeyFromAgent) result
freeMem username'
return result'
) (do
freeMem username'
)
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
#endif
foreign import ccall "ggit_cred_ssh_key_from_agent_get_username" ggit_cred_ssh_key_from_agent_get_username ::
Ptr CredSshKeyFromAgent ->
IO CString
credSshKeyFromAgentGetUsername ::
(B.CallStack.HasCallStack, MonadIO m, IsCredSshKeyFromAgent a) =>
a
-> m T.Text
credSshKeyFromAgentGetUsername cred = liftIO $ do
cred' <- unsafeManagedPtrCastPtr cred
result <- ggit_cred_ssh_key_from_agent_get_username cred'
checkUnexpectedReturnNULL "credSshKeyFromAgentGetUsername" result
result' <- cstringToText result
touchManagedPtr cred
return result'
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data CredSshKeyFromAgentGetUsernameMethodInfo
instance (signature ~ (m T.Text), MonadIO m, IsCredSshKeyFromAgent a) => O.MethodInfo CredSshKeyFromAgentGetUsernameMethodInfo a signature where
overloadedMethod _ = credSshKeyFromAgentGetUsername
#endif