diff options
author | William Carroll <wpcarro@gmail.com> | 2020-08-13T17·09+0100 |
---|---|---|
committer | William Carroll <wpcarro@gmail.com> | 2020-08-20T10·26+0100 |
commit | 81aa32fe71a0b8a822673b36a2ded9a427855286 (patch) | |
tree | dc505bcfa51ce2b332ba9f576711f6cc22692ece /website/sandbox/learnpianochords/src/server/App.hs | |
parent | de723c142b31afe6061fca243917dee88cc6c625 (diff) |
Support POST /create-payment-intent
Interact with Stripe's payment_intents API endpoint. I'm not committing the index.html that contains client-side code that interacts with the /create-payment-intent endpoint, but it contains sensitive information, so I'm omitting it for now. TL;DR: - Define POST /create-payment-intent endpoint - Include envStripeAPIKey in Context record - Define a top-level Stripe module for making API calls - Define types and instances that align with Stripes request and response types - Depend on the Req library: a higher-level library than http-client
Diffstat (limited to 'website/sandbox/learnpianochords/src/server/App.hs')
-rw-r--r-- | website/sandbox/learnpianochords/src/server/App.hs | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/website/sandbox/learnpianochords/src/server/App.hs b/website/sandbox/learnpianochords/src/server/App.hs index 92dee6045d46..e23757b01544 100644 --- a/website/sandbox/learnpianochords/src/server/App.hs +++ b/website/sandbox/learnpianochords/src/server/App.hs @@ -12,11 +12,13 @@ import Utils import qualified Network.Wai.Handler.Warp as Warp import qualified GoogleSignIn +import qualified Stripe import qualified Types as T -------------------------------------------------------------------------------- server :: T.Context -> Server API -server T.Context{..} = verifyGoogleSignIn +server ctx@T.Context{..} = verifyGoogleSignIn + :<|> createPaymentIntent where verifyGoogleSignIn :: T.VerifyGoogleSignInRequest -> Handler NoContent verifyGoogleSignIn T.VerifyGoogleSignInRequest{..} = do @@ -31,6 +33,11 @@ server T.Context{..} = verifyGoogleSignIn err -> do throwError err401 { errBody = err |> GoogleSignIn.explainResult |> cs } + createPaymentIntent :: T.PaymentIntent -> Handler T.CreatePaymentIntentResponse + createPaymentIntent pmt = do + clientSecret <- liftIO $ Stripe.createPaymentIntent ctx pmt + pure T.CreatePaymentIntentResponse{..} + run :: T.App run = do ctx@T.Context{..} <- ask |