 40ecf58d4b
			
		
	
	
	
	
	40ecf58d4bThis does not change the overall license of the git-annex program, which was already AGPL due to a number of sources files being AGPL already. Legally speaking, I'm adding a new license under which these files are now available; I already released their current contents under the GPL license. Now they're dual licensed GPL and AGPL. However, I intend for all my future changes to these files to only be released under the AGPL license, and I won't be tracking the dual licensing status, so I'm simply changing the license statement to say it's AGPL. (In some cases, others wrote parts of the code of a file and released it under the GPL; but in all cases I have contributed a significant portion of the code in each file and it's that code that is getting the AGPL license; the GPL license of other contributors allows combining with AGPL code.)
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			1.4 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			1.4 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
| {- git-annex command
 | |
|  -
 | |
|  - Copyright 2010 Joey Hess <id@joeyh.name>
 | |
|  -
 | |
|  - Licensed under the GNU AGPL version 3 or higher.
 | |
|  -}
 | |
| 
 | |
| module Command.RecvKey where
 | |
| 
 | |
| import Command
 | |
| import Annex.Content
 | |
| import Annex.Action
 | |
| import Annex
 | |
| import Utility.Rsync
 | |
| import Types.Transfer
 | |
| import Types.Remote (RetrievalSecurityPolicy(..))
 | |
| import Command.SendKey (fieldTransfer)
 | |
| import qualified CmdLine.GitAnnexShell.Fields as Fields
 | |
| 
 | |
| cmd :: Command
 | |
| cmd = noCommit $ command "recvkey" SectionPlumbing 
 | |
| 	"runs rsync in server mode to receive content"
 | |
| 	paramKey (withParams seek)
 | |
| 
 | |
| seek :: CmdParams -> CommandSeek
 | |
| seek = withKeys (commandAction . start)
 | |
| 
 | |
| start :: Key -> CommandStart
 | |
| start key = fieldTransfer Download key $ \_p -> do
 | |
| 	-- Always verify content when a repo is sending an unlocked file,
 | |
| 	-- as the file could change while being transferred.
 | |
| 	fromunlocked <- (isJust <$> Fields.getField Fields.unlocked)
 | |
| 		<||> (isJust <$> Fields.getField Fields.direct)
 | |
| 	let verify = if fromunlocked then AlwaysVerify else DefaultVerify
 | |
| 	-- This matches the retrievalSecurityPolicy of Remote.Git
 | |
| 	let rsp = RetrievalAllKeysSecure
 | |
| 	ifM (getViaTmp rsp verify key go)
 | |
| 		( do
 | |
| 			-- forcibly quit after receiving one key,
 | |
| 			-- and shutdown cleanly
 | |
| 			_ <- shutdown True
 | |
| 			return True
 | |
| 		, return False
 | |
| 		)
 | |
|   where
 | |
| 	go tmp = unVerified $ do
 | |
| 		opts <- filterRsyncSafeOptions . maybe [] words
 | |
| 			<$> getField "RsyncOptions"
 | |
| 		liftIO $ rsyncServerReceive (map Param opts) tmp
 |