28 lines
757 B
Haskell
28 lines
757 B
Haskell
|
{- git-remote-daemon, gcrypt transport
|
||
|
-
|
||
|
- Copyright 2015 Joey Hess <id@joeyh.name>
|
||
|
-
|
||
|
- Licensed under the GNU GPL version 3 or higher.
|
||
|
-}
|
||
|
|
||
|
module RemoteDaemon.Transport.GCrypt (transport) where
|
||
|
|
||
|
import Common.Annex
|
||
|
import RemoteDaemon.Types
|
||
|
import RemoteDaemon.Common
|
||
|
import RemoteDaemon.Transport.Ssh (transportUsingCmd)
|
||
|
import Git.GCrypt
|
||
|
import Remote.Helper.Ssh
|
||
|
import Remote.GCrypt (accessShellConfig)
|
||
|
|
||
|
transport :: Transport
|
||
|
transport rr@(RemoteRepo r gc) url h@(TransportHandle g _) ichan ochan
|
||
|
| accessShellConfig gc = do
|
||
|
r' <- encryptedRemote g r
|
||
|
v <- liftAnnex h $ git_annex_shell r' "notifychanges" [] []
|
||
|
case v of
|
||
|
Nothing -> noop
|
||
|
Just (cmd, params) ->
|
||
|
transportUsingCmd cmd params rr url h ichan ochan
|
||
|
| otherwise = noop
|