summaryrefslogtreecommitdiff
path: root/Assistant/RepoProblem.hs
blob: d2e5a5cf192774971f5c21120eeca1a95b4b06b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
{- git-annex assistant remote problem handling
 -
 - Copyright 2013 Joey Hess <joey@kitenet.net>
 -
 - Licensed under the GNU GPL version 3 or higher.
 -}

module Assistant.RepoProblem where

import Assistant.Common
import Utility.TList

import Control.Concurrent.STM

{- Gets all repositories that have problems. 
 - Blocks until there is at least one. -}
getRepoProblems :: Assistant [UUID]
getRepoProblems = (atomically . getTList) <<~ repoProblemChan

{- Indicates that there was a problem accessing a repo, and the problem
 - appears to not be a transient (eg network connection) problem. -}
repoHasProblem :: UUID -> Assistant ()
repoHasProblem r  = (atomically . flip consTList r) <<~ repoProblemChan