{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.SecurityPolicyViolationEvent
(newSecurityPolicyViolationEvent, getDocumentURI, getReferrer,
getBlockedURI, getViolatedDirective, getEffectiveDirective,
getOriginalPolicy, getSourceFile, getStatusCode, getLineNumber,
getColumnNumber, SecurityPolicyViolationEvent(..),
gTypeSecurityPolicyViolationEvent)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, realToFrac, fmap, Show, Read, Eq, Ord, Maybe(..))
import qualified Prelude (error)
import Data.Typeable (Typeable)
import Data.Traversable (mapM)
import Language.Javascript.JSaddle (JSM(..), JSVal(..), JSString, strictEqual, toJSVal, valToStr, valToNumber, valToBool, js, jss, jsf, jsg, function, asyncFunction, new, array, jsUndefined, (!), (!!))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import JSDOM.Types
import Control.Applicative ((<$>))
import Control.Monad (void)
import Control.Lens.Operators ((^.))
import JSDOM.EventTargetClosures (EventName, unsafeEventName, unsafeEventNameAsync)
import JSDOM.Enums
newSecurityPolicyViolationEvent ::
(MonadDOM m, ToJSString type') =>
type' ->
Maybe SecurityPolicyViolationEventInit ->
m SecurityPolicyViolationEvent
newSecurityPolicyViolationEvent :: type'
-> Maybe SecurityPolicyViolationEventInit
-> m SecurityPolicyViolationEvent
newSecurityPolicyViolationEvent type'
type' Maybe SecurityPolicyViolationEventInit
eventInitDict
= DOM SecurityPolicyViolationEvent -> m SecurityPolicyViolationEvent
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSVal -> SecurityPolicyViolationEvent
SecurityPolicyViolationEvent (JSVal -> SecurityPolicyViolationEvent)
-> JSM JSVal -> DOM SecurityPolicyViolationEvent
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
JSM JSVal -> [JSM JSVal] -> JSM JSVal
forall constructor args.
(MakeObject constructor, MakeArgs args) =>
constructor -> args -> JSM JSVal
new ([Char] -> JSM JSVal
forall a. ToJSString a => a -> JSM JSVal
jsg [Char]
"SecurityPolicyViolationEvent")
[type' -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal type'
type', Maybe SecurityPolicyViolationEventInit -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe SecurityPolicyViolationEventInit
eventInitDict])
getDocumentURI ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getDocumentURI :: SecurityPolicyViolationEvent -> m result
getDocumentURI SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"documentURI") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getReferrer ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getReferrer :: SecurityPolicyViolationEvent -> m result
getReferrer SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"referrer") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getBlockedURI ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getBlockedURI :: SecurityPolicyViolationEvent -> m result
getBlockedURI SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"blockedURI") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getViolatedDirective ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getViolatedDirective :: SecurityPolicyViolationEvent -> m result
getViolatedDirective SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"violatedDirective") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getEffectiveDirective ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getEffectiveDirective :: SecurityPolicyViolationEvent -> m result
getEffectiveDirective SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"effectiveDirective") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getOriginalPolicy ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getOriginalPolicy :: SecurityPolicyViolationEvent -> m result
getOriginalPolicy SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"originalPolicy") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getSourceFile ::
(MonadDOM m, FromJSString result) =>
SecurityPolicyViolationEvent -> m result
getSourceFile :: SecurityPolicyViolationEvent -> m result
getSourceFile SecurityPolicyViolationEvent
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"sourceFile") JSM JSVal -> (JSVal -> DOM result) -> DOM result
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getStatusCode ::
(MonadDOM m) => SecurityPolicyViolationEvent -> m Word
getStatusCode :: SecurityPolicyViolationEvent -> m Word
getStatusCode SecurityPolicyViolationEvent
self
= DOM Word -> m Word
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (Double -> Word
forall a b. (RealFrac a, Integral b) => a -> b
round (Double -> Word) -> JSM Double -> DOM Word
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"statusCode") JSM JSVal -> (JSVal -> JSM Double) -> JSM Double
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM Double
forall value. ToJSVal value => value -> JSM Double
valToNumber))
getLineNumber ::
(MonadDOM m) => SecurityPolicyViolationEvent -> m Int
getLineNumber :: SecurityPolicyViolationEvent -> m Int
getLineNumber SecurityPolicyViolationEvent
self
= DOM Int -> m Int
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (Double -> Int
forall a b. (RealFrac a, Integral b) => a -> b
round (Double -> Int) -> JSM Double -> DOM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"lineNumber") JSM JSVal -> (JSVal -> JSM Double) -> JSM Double
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM Double
forall value. ToJSVal value => value -> JSM Double
valToNumber))
getColumnNumber ::
(MonadDOM m) => SecurityPolicyViolationEvent -> m Int
getColumnNumber :: SecurityPolicyViolationEvent -> m Int
getColumnNumber SecurityPolicyViolationEvent
self
= DOM Int -> m Int
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (Double -> Int
forall a b. (RealFrac a, Integral b) => a -> b
round (Double -> Int) -> JSM Double -> DOM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((SecurityPolicyViolationEvent
self SecurityPolicyViolationEvent
-> Getting (JSM JSVal) SecurityPolicyViolationEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter SecurityPolicyViolationEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"columnNumber") JSM JSVal -> (JSVal -> JSM Double) -> JSM Double
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM Double
forall value. ToJSVal value => value -> JSM Double
valToNumber))