webapp: Encryption can be disabled when setting up remotes.

This commit is contained in:
Joey Hess 2012-12-04 13:28:22 -04:00
parent cf999689f7
commit c9fd389fbf
7 changed files with 31 additions and 9 deletions

View file

@ -52,6 +52,7 @@ data AWSInput = AWSInput
-- Only used for S3, not Glacier. -- Only used for S3, not Glacier.
, storageClass :: StorageClass , storageClass :: StorageClass
, repoName :: Text , repoName :: Text
, enableEncryption :: EnableEncryption
} }
data AWSCreds = AWSCreds Text Text data AWSCreds = AWSCreds Text Text
@ -66,6 +67,7 @@ s3InputAForm = AWSInput
<*> datacenterField AWS.S3 <*> datacenterField AWS.S3
<*> areq (selectFieldList storageclasses) "Storage class" (Just StandardRedundancy) <*> areq (selectFieldList storageclasses) "Storage class" (Just StandardRedundancy)
<*> areq textField "Repository name" (Just "S3") <*> areq textField "Repository name" (Just "S3")
<*> enableEncryptionField
where where
storageclasses :: [(Text, StorageClass)] storageclasses :: [(Text, StorageClass)]
storageclasses = storageclasses =
@ -80,6 +82,7 @@ glacierInputAForm = AWSInput
<*> datacenterField AWS.Glacier <*> datacenterField AWS.Glacier
<*> pure StandardRedundancy <*> pure StandardRedundancy
<*> areq textField "Repository name" (Just "glacier") <*> areq textField "Repository name" (Just "glacier")
<*> enableEncryptionField
awsCredsAForm :: AForm WebApp WebApp AWSCreds awsCredsAForm :: AForm WebApp WebApp AWSCreds
awsCredsAForm = AWSCreds awsCredsAForm = AWSCreds
@ -112,7 +115,7 @@ getAddS3R = awsConfigurator $ do
FormSuccess input -> lift $ do FormSuccess input -> lift $ do
let name = T.unpack $ repoName input let name = T.unpack $ repoName input
makeAWSRemote S3.remote (extractCreds input) name setgroup $ M.fromList makeAWSRemote S3.remote (extractCreds input) name setgroup $ M.fromList
[ ("encryption", "shared") [ configureEncryption $ enableEncryption input
, ("type", "S3") , ("type", "S3")
, ("datacenter", T.unpack $ datacenter input) , ("datacenter", T.unpack $ datacenter input)
, ("storageclass", show $ storageClass input) , ("storageclass", show $ storageClass input)
@ -133,7 +136,7 @@ getAddGlacierR = glacierConfigurator $ do
FormSuccess input -> lift $ do FormSuccess input -> lift $ do
let name = T.unpack $ repoName input let name = T.unpack $ repoName input
makeAWSRemote Glacier.remote (extractCreds input) name setgroup $ M.fromList makeAWSRemote Glacier.remote (extractCreds input) name setgroup $ M.fromList
[ ("encryption", "shared") [ configureEncryption $ enableEncryption input
, ("type", "glacier") , ("type", "glacier")
, ("datacenter", T.unpack $ datacenter input) , ("datacenter", T.unpack $ datacenter input)
] ]

View file

@ -36,6 +36,7 @@ data WebDAVInput = WebDAVInput
, password :: Text , password :: Text
, embedCreds :: Bool , embedCreds :: Bool
, directory :: Text , directory :: Text
, enableEncryption :: EnableEncryption
} }
toCredPair :: WebDAVInput -> CredPair toCredPair :: WebDAVInput -> CredPair
@ -47,6 +48,7 @@ boxComAForm = WebDAVInput
<*> areq passwordField "Box.com Password" Nothing <*> areq passwordField "Box.com Password" Nothing
<*> areq checkBoxField "Share this account with friends?" (Just True) <*> areq checkBoxField "Share this account with friends?" (Just True)
<*> areq textField "Directory" (Just "annex") <*> areq textField "Directory" (Just "annex")
<*> enableEncryptionField
webDAVCredsAForm :: AForm WebApp WebApp WebDAVInput webDAVCredsAForm :: AForm WebApp WebApp WebDAVInput
webDAVCredsAForm = WebDAVInput webDAVCredsAForm = WebDAVInput
@ -54,6 +56,7 @@ webDAVCredsAForm = WebDAVInput
<*> areq passwordField "Password" Nothing <*> areq passwordField "Password" Nothing
<*> pure False <*> pure False
<*> pure T.empty <*> pure T.empty
<*> pure NoEncryption -- not used!
getAddBoxComR :: Handler RepHtml getAddBoxComR :: Handler RepHtml
#ifdef WITH_WEBDAV #ifdef WITH_WEBDAV
@ -63,7 +66,7 @@ getAddBoxComR = boxConfigurator $ do
case result of case result of
FormSuccess input -> lift $ FormSuccess input -> lift $
makeWebDavRemote "box.com" (toCredPair input) setgroup $ M.fromList makeWebDavRemote "box.com" (toCredPair input) setgroup $ M.fromList
[ ("encryption", "shared") [ configureEncryption $ enableEncryption input
, ("embedcreds", if embedCreds input then "yes" else "no") , ("embedcreds", if embedCreds input then "yes" else "no")
, ("type", "webdav") , ("type", "webdav")
, ("url", "https://www.box.com/dav/" ++ T.unpack (directory input)) , ("url", "https://www.box.com/dav/" ++ T.unpack (directory input))

View file

@ -9,6 +9,8 @@
module Assistant.WebApp.Form where module Assistant.WebApp.Form where
import Types.Remote (RemoteConfigKey)
import Yesod hiding (textField, passwordField) import Yesod hiding (textField, passwordField)
import Yesod.Form.Fields as F import Yesod.Form.Fields as F
import Data.Text (Text) import Data.Text (Text)
@ -42,3 +44,22 @@ withNote field note = field { fieldView = newview }
newview theId name attrs val isReq = newview theId name attrs val isReq =
let fieldwidget = (fieldView field) theId name attrs val isReq let fieldwidget = (fieldView field) theId name attrs val isReq
in [whamlet|^{fieldwidget}&nbsp;&nbsp;<span>^{note}</span>|] in [whamlet|^{fieldwidget}&nbsp;&nbsp;<span>^{note}</span>|]
data EnableEncryption = SharedEncryption | NoEncryption
deriving (Eq)
{- Adds a check box to an AForm to control encryption. -}
enableEncryptionField :: RenderMessage master FormMessage => AForm sub master EnableEncryption
enableEncryptionField = areq (selectFieldList choices) "Encryption" (Just SharedEncryption)
where
choices :: [(Text, EnableEncryption)]
choices =
[ ("Encrypt all data", SharedEncryption)
, ("Disable encryption", NoEncryption)
]
{- Generates Remote configuration for encryption. -}
configureEncryption :: EnableEncryption -> (RemoteConfigKey, String)
configureEncryption SharedEncryption = ("encryption", "shared")
configureEncryption NoEncryption = ("encryption", "none")

1
debian/changelog vendored
View file

@ -19,6 +19,7 @@ git-annex (3.20121128) UNRELEASED; urgency=low
* webapp: Fix bad interaction between required fields and modals. * webapp: Fix bad interaction between required fields and modals.
* webapp: Added help buttons and links next to fields that require * webapp: Added help buttons and links next to fields that require
explanations. explanations.
* webapp: Encryption can be disabled when setting up remotes.
-- Joey Hess <joeyh@debian.org> Wed, 28 Nov 2012 13:31:07 -0400 -- Joey Hess <joeyh@debian.org> Wed, 28 Nov 2012 13:31:07 -0400

View file

@ -7,8 +7,6 @@
<p> <p>
Even a small amount of free storage is useful, as a transfer point # Even a small amount of free storage is useful, as a transfer point #
between your repositories. between your repositories.
<p>
All data will be encrypted before being sent to Box.com.
<p> <p>
<form .form-horizontal enctype=#{enctype}> <form .form-horizontal enctype=#{enctype}>
<fieldset> <fieldset>

View file

@ -15,8 +15,6 @@
monthly fee for data storage. # monthly fee for data storage. #
<a href="http://aws.amazon.com/glacier/pricing/"> <a href="http://aws.amazon.com/glacier/pricing/">
Pricing details Pricing details
<p>
All data will be encrypted before being sent to Amazon Glacier.
<p> <p>
<form .form-horizontal enctype=#{enctype}> <form .form-horizontal enctype=#{enctype}>
<fieldset> <fieldset>

View file

@ -11,8 +11,6 @@
for data storage. # for data storage. #
<a href="http://aws.amazon.com/s3/pricing/"> <a href="http://aws.amazon.com/s3/pricing/">
Pricing details, including one year Free Usage Tier promotion Pricing details, including one year Free Usage Tier promotion
<p>
All data will be encrypted before being sent to Amazon S3.
<p> <p>
<form .form-horizontal enctype=#{enctype}> <form .form-horizontal enctype=#{enctype}>
<fieldset> <fieldset>