summaryrefslogtreecommitdiff
path: root/src/Sync.hs
blob: 37941b82c9f4fe7d90b3d22d1dbe15f9e516b919 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
module Sync (
    SyncService,
    ServicePacket(..),
) where

import Control.Monad

import Data.List

import Service
import State
import Storage
import Storage.Merge

data SyncService

instance Service SyncService where
    serviceID _ = mkServiceID "a4f538d0-4e50-4082-8e10-7e3ec2af175d"

    data ServiceState SyncService = SyncService
    emptyServiceState = SyncService

    newtype ServicePacket SyncService = SyncPacket (Stored SharedState)

    serviceHandler packet = do
        let SyncPacket added = fromStored packet
        ls <- svcGetLocal
        let st = storedStorage ls
            current = sort $ lsShared $ fromStored ls
            updated = filterAncestors (added : current)
        when (current /= updated) $ do
            svcSetLocal =<< wrappedStore st (fromStored ls) { lsShared = updated }

instance Storable (ServicePacket SyncService) where
    store' (SyncPacket smsg) = store' smsg
    load' = SyncPacket <$> load'