update
This commit is contained in:
		
					parent
					
						
							
								a535eaa176
							
						
					
				
			
			
				commit
				
					
						84d27cf34f
					
				
			
		
					 1 changed files with 17 additions and 3 deletions
				
			
		|  | @ -545,6 +545,10 @@ it pick which of multiple branches to export? | ||||||
| Perhaps configure the annex-tracking-branch in the git-annex branch? | Perhaps configure the annex-tracking-branch in the git-annex branch? | ||||||
| That might be generally useful when working with exporttree=yes remotes. | That might be generally useful when working with exporttree=yes remotes. | ||||||
| 
 | 
 | ||||||
|  | Or simply configure remote.foo.annex-tracking-branch on the proxy. | ||||||
|  | This may not meet all use cases, but it's simple and seems like a | ||||||
|  | reasonable first step. | ||||||
|  | 
 | ||||||
| The first two approaches also have a complication when a key is sent to | The first two approaches also have a complication when a key is sent to | ||||||
| the proxy that is not part of the configured annex-tracking-branch. What | the proxy that is not part of the configured annex-tracking-branch. What | ||||||
| does the proxy do with it? There seem three possibilities: | does the proxy do with it? There seem three possibilities: | ||||||
|  | @ -610,9 +614,7 @@ were not accessible when it is accessed directly rather than via the proxy. | ||||||
| Simplified design for proxying to exporttree=yes, if those remotes can | Simplified design for proxying to exporttree=yes, if those remotes can | ||||||
| store any key: | store any key: | ||||||
| 
 | 
 | ||||||
| * Configure annex-tracking-branch for the proxy in the git-annex branch. | * Configure annex-tracking-branch in the proxy's git config. | ||||||
|   (For the proxy as a whole, or for specific exporttree=yes repos behind |  | ||||||
|   it?) |  | ||||||
| * Then the user's workflow is simply: `git-annex push` | * Then the user's workflow is simply: `git-annex push` | ||||||
| * The proxy handles PUT/GET/REMOVE of a key that is not in the  | * The proxy handles PUT/GET/REMOVE of a key that is not in the  | ||||||
|   annex-tracking branch that it currently knows about, by using |   annex-tracking branch that it currently knows about, by using | ||||||
|  | @ -623,6 +625,18 @@ store any key: | ||||||
|   eg upon receiving a key, just proxy it on to the exporttree=yes remote, |   eg upon receiving a key, just proxy it on to the exporttree=yes remote, | ||||||
|   and update the export database. Once all keys are received, update |   and update the export database. Once all keys are received, update | ||||||
|   the git-annex branch to indicate a new tree has been exported. |   the git-annex branch to indicate a new tree has been exported. | ||||||
|  | * `git-annex sync` may optionally push updates to the annex-tracking-branch | ||||||
|  |   before sending content. This can let the proxy be more efficient, | ||||||
|  |   especially when the special remote does not support renaming. | ||||||
|  | 
 | ||||||
|  | Note that this necessarily means that an object that the client uploads | ||||||
|  | once to the proxy might need to be uploaded multiple times from the proxy | ||||||
|  | to the special remote. Eg, if a key is used 10 times in a tree, it will | ||||||
|  | need to upload 10 times. Adding a "copy" operation to exportActions would | ||||||
|  | avoid this problem, but only for special remotes that were able to | ||||||
|  | implement it. Even a rename of a single file can need the proxy to download | ||||||
|  | it from the special remote and upload it back under a new name, when the | ||||||
|  | special remote does not support renames. | ||||||
| 
 | 
 | ||||||
| ## possible enhancement: indirect uploads | ## possible enhancement: indirect uploads | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Joey Hess
				Joey Hess