{-# LANGUAGE TemplateHaskell #-} -- This file is part of the Wire Server implementation. -- -- Copyright (C) 2022 Wire Swiss GmbH <opensource@wire.com> -- -- This program is free software: you can redistribute it and/or modify it under -- the terms of the GNU Affero General Public License as published by the Free -- Software Foundation, either version 3 of the License, or (at your option) any -- later version. -- -- This program is distributed in the hope that it will be useful, but WITHOUT -- ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -- FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more -- details. -- -- You should have received a copy of the GNU Affero General Public License along -- with this program. If not, see <https://www.gnu.org/licenses/>. module Galley.Effects.ProposalStore where import Imports import Polysemy import Wire.API.MLS.Epoch import Wire.API.MLS.Group import Wire.API.MLS.Proposal import Wire.API.MLS.Serialisation data ProposalStore m a where StoreProposal :: GroupId -> Epoch -> ProposalRef -> ProposalOrigin -> RawMLS Proposal -> ProposalStore m () GetProposal :: GroupId -> Epoch -> ProposalRef -> ProposalStore m (Maybe (RawMLS Proposal)) GetAllPendingProposalRefs :: GroupId -> Epoch -> ProposalStore m [ProposalRef] GetAllPendingProposals :: GroupId -> Epoch -> ProposalStore m [(Maybe ProposalOrigin, RawMLS Proposal)] DeleteAllProposals :: GroupId -> ProposalStore m () makeSem ''ProposalStore