1
0
Fork 0
mirror of https://code.naskya.net/repos/ndqEd synced 2025-01-10 11:06:46 +09:00

Make key storage limits configurable instead of hardcoding to 2

This commit is contained in:
fr33domlover 2019-02-24 01:35:07 +00:00
parent 17524b6ee1
commit 2e705b6868
3 changed files with 27 additions and 8 deletions

View file

@ -76,6 +76,9 @@ database:
database: "_env:PGDATABASE:vervis_dev"
poolsize: "_env:PGPOOLSIZE:10"
max-instance-keys: 2
max-actor-keys: 2
###############################################################################
# Version control repositories
###############################################################################

View file

@ -598,10 +598,14 @@ instanceAndActor host luActor luInbox = do
idAndNew (Right iid) = (iid, True)
actorRoom :: RemoteSharerId -> AppDB Bool
actorRoom rsid =
sumUpTo 2
(count [VerifKeySharedUsageUser ==. rsid])
(count [VerifKeySharer ==. Just rsid])
actorRoom rsid = do
mn <- getsYesod $ appMaxActorKeys . appSettings
case mn of
Nothing -> pure True
Just n ->
sumUpTo n
(count [VerifKeySharedUsageUser ==. rsid])
(count [VerifKeySharer ==. Just rsid])
-- | Given a shared key we have in our DB, verify that the given actor lists
-- this key, and update the DB accordingly.
@ -805,10 +809,14 @@ instance YesodHttpSig App where
vkid <- insert $ VerifKey luKey iid mexpires key Nothing
insert_ $ VerifKeySharedUsage vkid rsid
return $ Right ()
else return $ Left "We already store 2 keys"
else return $ Left "We've reached key storage limit"
where
instanceRoom iid =
(< 2) <$> count [VerifKeyInstance ==. iid, VerifKeySharer ==. Nothing]
instanceRoom iid = do
mn <- getsYesod $ appMaxInstanceKeys . appSettings
case mn of
Nothing -> pure True
Just n ->
(< n) <$> count [VerifKeyInstance ==. iid, VerifKeySharer ==. Nothing]
addPersonalKey host luInbox (VerifKeyDetail luKey key mexpires luActor _) = do
(iid, rsid, inew) <- instanceAndActor host luActor luInbox
room <-
@ -819,7 +827,7 @@ instance YesodHttpSig App where
then do
insert_ $ VerifKey luKey iid mexpires key (Just rsid)
return $ Right ()
else return $ Left "We already store 2 keys"
else return $ Left "We've reached key storage limit"
updateVerifKey vkid vkd =
update vkid [VerifKeyExpires =. vkdExpires vkd, VerifKeyPublic =. vkdKey vkd]

View file

@ -50,6 +50,12 @@ data AppSettings = AppSettings
appStaticDir :: String
-- | Configuration settings for accessing the database.
, appDatabaseConf :: PostgresConf
-- | Maximal number of remote instance-scope keys to cache in our local
-- database per instance.
, appMaxInstanceKeys :: Maybe Int
-- | Maximal number of keys (personal keys or usage of shared keys) to
-- remember cached in our database per remote actor.
, appMaxActorKeys :: Maybe Int
-- | Base for all generated URLs. If @Nothing@, determined from the
-- request headers.
, appRoot :: Maybe Text
@ -119,6 +125,8 @@ instance FromJSON AppSettings where
#endif
appStaticDir <- o .: "static-dir"
appDatabaseConf <- o .: "database"
appMaxInstanceKeys <- o .:? "max-instance-keys"
appMaxActorKeys <- o .:? "max-actor-keys"
appRoot <- o .:? "approot"
appHost <- fromString <$> o .: "host"
appPort <- o .: "http-port"