module JSDOM.Custom.SQLTransaction ( module Generated , executeSql' , executeSql , executeSql_ ) where import Data.Maybe (fromJust) import Control.Monad (void) import Control.Concurrent.MVar (takeMVar, putMVar, newEmptyMVar) import Control.Monad.IO.Class (MonadIO(..)) import JSDOM.Types (withCallback, Callback(..), SQLResultSet(..), SQLError(..), IsObjectArray, MonadDOM, ToJSString, SQLStatementCallback(..), SQLStatementErrorCallback(..)) import JSDOM.Custom.SQLError (throwSQLException) import JSDOM.Generated.SQLStatementCallback (newSQLStatementCallback) import JSDOM.Generated.SQLStatementErrorCallback (newSQLStatementErrorCallback) import JSDOM.Generated.SQLTransaction as Generated hiding (executeSql) import qualified JSDOM.Generated.SQLTransaction as Generated (executeSql) executeSql' :: (MonadDOM m, ToJSString sqlStatement, IsObjectArray arguments) => SQLTransaction -> sqlStatement -> Maybe arguments -> m (Either SQLError SQLResultSet) executeSql' self sqlStatement arguments = do result <- liftIO newEmptyMVar withCallback (newSQLStatementCallback (\tx rs -> liftIO . putMVar result . Right $ fromJust rs)) $ \success -> withCallback (newSQLStatementErrorCallback (\tx e -> liftIO . putMVar result . Left $ fromJust e)) $ \error -> do Generated.executeSql self sqlStatement arguments (Just success) (Just error) liftIO $ takeMVar result executeSql :: (MonadDOM m, ToJSString sqlStatement, IsObjectArray arguments) => SQLTransaction -> sqlStatement -> Maybe arguments -> m SQLResultSet executeSql self sqlStatement arguments = executeSql' self sqlStatement arguments >>= either throwSQLException return executeSql_ :: (MonadDOM m, ToJSString sqlStatement, IsObjectArray arguments) => SQLTransaction -> sqlStatement -> Maybe arguments -> m () executeSql_ self sqlStatement arguments = void $ executeSql self sqlStatement arguments