mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-31 08:11:24 +01:00 
			
		
		
		
	Merge pull request #2716 from matrix-org/rav/federation_client_post
federation_client script: Support for posting content
This commit is contained in:
		
						commit
						58ebdb037c
					
				| @ -123,15 +123,25 @@ def lookup(destination, path): | |||||||
|         except: |         except: | ||||||
|             return "https://%s:%d%s" % (destination, 8448, path) |             return "https://%s:%d%s" % (destination, 8448, path) | ||||||
| 
 | 
 | ||||||
| def get_json(origin_name, origin_key, destination, path): | 
 | ||||||
|     request_json = { | def request_json(method, origin_name, origin_key, destination, path, content): | ||||||
|         "method": "GET", |     if method is None: | ||||||
|  |         if content is None: | ||||||
|  |             method = "GET" | ||||||
|  |         else: | ||||||
|  |             method = "POST" | ||||||
|  | 
 | ||||||
|  |     json_to_sign = { | ||||||
|  |         "method": method, | ||||||
|         "uri": path, |         "uri": path, | ||||||
|         "origin": origin_name, |         "origin": origin_name, | ||||||
|         "destination": destination, |         "destination": destination, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     signed_json = sign_json(request_json, origin_key, origin_name) |     if content is not None: | ||||||
|  |         json_to_sign["content"] = json.loads(content) | ||||||
|  | 
 | ||||||
|  |     signed_json = sign_json(json_to_sign, origin_key, origin_name) | ||||||
| 
 | 
 | ||||||
|     authorization_headers = [] |     authorization_headers = [] | ||||||
| 
 | 
 | ||||||
| @ -145,10 +155,12 @@ def get_json(origin_name, origin_key, destination, path): | |||||||
|     dest = lookup(destination, path) |     dest = lookup(destination, path) | ||||||
|     print ("Requesting %s" % dest, file=sys.stderr) |     print ("Requesting %s" % dest, file=sys.stderr) | ||||||
| 
 | 
 | ||||||
|     result = requests.get( |     result = requests.request( | ||||||
|         dest, |         method=method, | ||||||
|  |         url=dest, | ||||||
|         headers={"Authorization": authorization_headers[0]}, |         headers={"Authorization": authorization_headers[0]}, | ||||||
|         verify=False, |         verify=False, | ||||||
|  |         data=content, | ||||||
|     ) |     ) | ||||||
|     sys.stderr.write("Status Code: %d\n" % (result.status_code,)) |     sys.stderr.write("Status Code: %d\n" % (result.status_code,)) | ||||||
|     return result.json() |     return result.json() | ||||||
| @ -186,6 +198,17 @@ def main(): | |||||||
|              "connect appropriately.", |              "connect appropriately.", | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|  |     parser.add_argument( | ||||||
|  |         "-X", "--method", | ||||||
|  |         help="HTTP method to use for the request. Defaults to GET if --data is" | ||||||
|  |              "unspecified, POST if it is." | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  |     parser.add_argument( | ||||||
|  |         "--body", | ||||||
|  |         help="Data to send as the body of the HTTP request" | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|     parser.add_argument( |     parser.add_argument( | ||||||
|         "path", |         "path", | ||||||
|         help="request path. We will add '/_matrix/federation/v1/' to this." |         help="request path. We will add '/_matrix/federation/v1/' to this." | ||||||
| @ -199,8 +222,11 @@ def main(): | |||||||
|     with open(args.signing_key_path) as f: |     with open(args.signing_key_path) as f: | ||||||
|         key = read_signing_keys(f)[0] |         key = read_signing_keys(f)[0] | ||||||
| 
 | 
 | ||||||
|     result = get_json( |     result = request_json( | ||||||
|         args.server_name, key, args.destination, "/_matrix/federation/v1/" + args.path |         args.method, | ||||||
|  |         args.server_name, key, args.destination, | ||||||
|  |         "/_matrix/federation/v1/" + args.path, | ||||||
|  |         content=args.body, | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     json.dump(result, sys.stdout) |     json.dump(result, sys.stdout) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user