This 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
 |