allow downloading via viewsrc to support client side e2ee
This commit is contained in:
		| @@ -13,6 +13,7 @@ class Viewsrc extends \Zotlabs\Web\Controller { | |||||||
| 	 | 	 | ||||||
| 		$item_id = ((argc() > 1) ? intval(argv(1)) : 0); | 		$item_id = ((argc() > 1) ? intval(argv(1)) : 0); | ||||||
| 		$json    = ((argc() > 2 && argv(2) === 'json') ? true : false); | 		$json    = ((argc() > 2 && argv(2) === 'json') ? true : false); | ||||||
|  | 		$dload   = ((argc() > 2 && argv(2) === 'download') ? true : false); | ||||||
| 	 | 	 | ||||||
| 		if(! local_channel()) { | 		if(! local_channel()) { | ||||||
| 			notice( t('Permission denied.') . EOL); | 			notice( t('Permission denied.') . EOL); | ||||||
| @@ -27,7 +28,7 @@ class Viewsrc extends \Zotlabs\Web\Controller { | |||||||
| 		$item_normal = item_normal(); | 		$item_normal = item_normal(); | ||||||
| 	 | 	 | ||||||
| 		if(local_channel() && $item_id) { | 		if(local_channel() && $item_id) { | ||||||
| 			$r = q("select id, item_flags, item_obscured, body from item where uid in (%d , %d) and id = %d $item_normal limit 1", | 			$r = q("select id, item_flags, mimetype, item_obscured, body from item where uid in (%d , %d) and id = %d $item_normal limit 1", | ||||||
| 				intval(local_channel()), | 				intval(local_channel()), | ||||||
| 				intval($sys['channel_id']), | 				intval($sys['channel_id']), | ||||||
| 				intval($item_id) | 				intval($item_id) | ||||||
| @@ -37,6 +38,14 @@ class Viewsrc extends \Zotlabs\Web\Controller { | |||||||
| 				if(intval($r[0]['item_obscured'])) | 				if(intval($r[0]['item_obscured'])) | ||||||
| 					$r[0]['body'] = crypto_unencapsulate(json_decode($r[0]['body'],true),get_config('system','prvkey'));  | 					$r[0]['body'] = crypto_unencapsulate(json_decode($r[0]['body'],true),get_config('system','prvkey'));  | ||||||
|  |  | ||||||
|  | 				if($dload) { | ||||||
|  | 					header('Content-type: ' . $r[0]['mimetype']); | ||||||
|  | 					header('Content-disposition: attachment; filename="' . t('item') . '-' . $item_id . '"' ); | ||||||
|  | 					echo $r[0]['body']; | ||||||
|  | 					killme(); | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  |  | ||||||
| 				$content = escape_tags($r[0]['body']); | 				$content = escape_tags($r[0]['body']); | ||||||
| 				$o = (($json) ? json_encode($content) : str_replace("\n",'<br />',$content)); | 				$o = (($json) ? json_encode($content) : str_replace("\n",'<br />',$content)); | ||||||
| 			} | 			} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user