module GI.WebKit.Objects.NetworkRequest
(
NetworkRequest(..) ,
NetworkRequestK ,
toNetworkRequest ,
noNetworkRequest ,
networkRequestGetMessage ,
networkRequestGetUri ,
networkRequestNew ,
networkRequestSetUri ,
NetworkRequestMessagePropertyInfo ,
constructNetworkRequestMessage ,
getNetworkRequestMessage ,
NetworkRequestUriPropertyInfo ,
constructNetworkRequestUri ,
getNetworkRequestUri ,
setNetworkRequestUri ,
) where
import Prelude ()
import Data.GI.Base.ShortPrelude
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import GI.WebKit.Types
import GI.WebKit.Callbacks
import qualified GI.GObject as GObject
import qualified GI.Soup as Soup
newtype NetworkRequest = NetworkRequest (ForeignPtr NetworkRequest)
foreign import ccall "webkit_network_request_get_type"
c_webkit_network_request_get_type :: IO GType
type instance ParentTypes NetworkRequest = NetworkRequestParentTypes
type NetworkRequestParentTypes = '[GObject.Object]
instance GObject NetworkRequest where
gobjectIsInitiallyUnowned _ = False
gobjectType _ = c_webkit_network_request_get_type
class GObject o => NetworkRequestK o
instance (GObject o, IsDescendantOf NetworkRequest o) => NetworkRequestK o
toNetworkRequest :: NetworkRequestK o => o -> IO NetworkRequest
toNetworkRequest = unsafeCastTo NetworkRequest
noNetworkRequest :: Maybe NetworkRequest
noNetworkRequest = Nothing
getNetworkRequestMessage :: (MonadIO m, NetworkRequestK o) => o -> m Soup.Message
getNetworkRequestMessage obj = liftIO $ getObjectPropertyObject obj "message" Soup.Message
constructNetworkRequestMessage :: (Soup.MessageK a) => a -> IO ([Char], GValue)
constructNetworkRequestMessage val = constructObjectPropertyObject "message" val
data NetworkRequestMessagePropertyInfo
instance AttrInfo NetworkRequestMessagePropertyInfo where
type AttrAllowedOps NetworkRequestMessagePropertyInfo = '[ 'AttrConstruct, 'AttrGet]
type AttrSetTypeConstraint NetworkRequestMessagePropertyInfo = Soup.MessageK
type AttrBaseTypeConstraint NetworkRequestMessagePropertyInfo = NetworkRequestK
type AttrGetType NetworkRequestMessagePropertyInfo = Soup.Message
type AttrLabel NetworkRequestMessagePropertyInfo = "NetworkRequest::message"
attrGet _ = getNetworkRequestMessage
attrSet _ = undefined
attrConstruct _ = constructNetworkRequestMessage
getNetworkRequestUri :: (MonadIO m, NetworkRequestK o) => o -> m T.Text
getNetworkRequestUri obj = liftIO $ getObjectPropertyString obj "uri"
setNetworkRequestUri :: (MonadIO m, NetworkRequestK o) => o -> T.Text -> m ()
setNetworkRequestUri obj val = liftIO $ setObjectPropertyString obj "uri" val
constructNetworkRequestUri :: T.Text -> IO ([Char], GValue)
constructNetworkRequestUri val = constructObjectPropertyString "uri" val
data NetworkRequestUriPropertyInfo
instance AttrInfo NetworkRequestUriPropertyInfo where
type AttrAllowedOps NetworkRequestUriPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet]
type AttrSetTypeConstraint NetworkRequestUriPropertyInfo = (~) T.Text
type AttrBaseTypeConstraint NetworkRequestUriPropertyInfo = NetworkRequestK
type AttrGetType NetworkRequestUriPropertyInfo = T.Text
type AttrLabel NetworkRequestUriPropertyInfo = "NetworkRequest::uri"
attrGet _ = getNetworkRequestUri
attrSet _ = setNetworkRequestUri
attrConstruct _ = constructNetworkRequestUri
type instance AttributeList NetworkRequest = NetworkRequestAttributeList
type NetworkRequestAttributeList = ('[ '("message", NetworkRequestMessagePropertyInfo), '("uri", NetworkRequestUriPropertyInfo)] :: [(Symbol, *)])
type instance SignalList NetworkRequest = NetworkRequestSignalList
type NetworkRequestSignalList = ('[ '("notify", GObject.ObjectNotifySignalInfo), '("notify::[property]", GObjectNotifySignalInfo)] :: [(Symbol, *)])
foreign import ccall "webkit_network_request_new" webkit_network_request_new ::
CString ->
IO (Ptr NetworkRequest)
networkRequestNew ::
(MonadIO m) =>
T.Text ->
m NetworkRequest
networkRequestNew uri = liftIO $ do
uri' <- textToCString uri
result <- webkit_network_request_new uri'
checkUnexpectedReturnNULL "webkit_network_request_new" result
result' <- (wrapObject NetworkRequest) result
freeMem uri'
return result'
foreign import ccall "webkit_network_request_get_message" webkit_network_request_get_message ::
Ptr NetworkRequest ->
IO (Ptr Soup.Message)
networkRequestGetMessage ::
(MonadIO m, NetworkRequestK a) =>
a ->
m Soup.Message
networkRequestGetMessage _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_network_request_get_message _obj'
checkUnexpectedReturnNULL "webkit_network_request_get_message" result
result' <- (newObject Soup.Message) result
touchManagedPtr _obj
return result'
foreign import ccall "webkit_network_request_get_uri" webkit_network_request_get_uri ::
Ptr NetworkRequest ->
IO CString
networkRequestGetUri ::
(MonadIO m, NetworkRequestK a) =>
a ->
m T.Text
networkRequestGetUri _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_network_request_get_uri _obj'
checkUnexpectedReturnNULL "webkit_network_request_get_uri" result
result' <- cstringToText result
touchManagedPtr _obj
return result'
foreign import ccall "webkit_network_request_set_uri" webkit_network_request_set_uri ::
Ptr NetworkRequest ->
CString ->
IO ()
networkRequestSetUri ::
(MonadIO m, NetworkRequestK a) =>
a ->
T.Text ->
m ()
networkRequestSetUri _obj uri = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
uri' <- textToCString uri
webkit_network_request_set_uri _obj' uri'
touchManagedPtr _obj
freeMem uri'
return ()