fix renaming of wiki pages
This commit is contained in:
		| @@ -77,6 +77,7 @@ class NativeWikiPage { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static public function rename_page($arr) { | 	static public function rename_page($arr) { | ||||||
|  |  | ||||||
| 		$pageUrlName   = ((array_key_exists('pageUrlName',$arr))   ? $arr['pageUrlName']   : ''); | 		$pageUrlName   = ((array_key_exists('pageUrlName',$arr))   ? $arr['pageUrlName']   : ''); | ||||||
| 		$pageNewName   = ((array_key_exists('pageNewName',$arr))   ? $arr['pageNewName']   : ''); | 		$pageNewName   = ((array_key_exists('pageNewName',$arr))   ? $arr['pageNewName']   : ''); | ||||||
| 		$resource_id   = ((array_key_exists('resource_id',$arr))   ? $arr['resource_id']   : ''); | 		$resource_id   = ((array_key_exists('resource_id',$arr))   ? $arr['resource_id']   : ''); | ||||||
| @@ -229,6 +230,8 @@ class NativeWikiPage { | |||||||
| 			$sql_extra .= " and revision = " . intval($revision) . " "; | 			$sql_extra .= " and revision = " . intval($revision) . " "; | ||||||
|  |  | ||||||
| 		$r = null; | 		$r = null; | ||||||
|  |  | ||||||
|  |  | ||||||
| 		if($ids) { | 		if($ids) { | ||||||
| 			$r = q("select * from item where resource_type = 'nwikipage' and resource_id = '%s' and uid = %d and id in ( $ids ) $sql_extra limit 1", | 			$r = q("select * from item where resource_type = 'nwikipage' and resource_id = '%s' and uid = %d and id in ( $ids ) $sql_extra limit 1", | ||||||
| 				dbesc($resource_id), | 				dbesc($resource_id), | ||||||
| @@ -487,6 +490,7 @@ class NativeWikiPage { | |||||||
| 			return array('message' => t('Error reading wiki'), 'success' => false); | 			return array('message' => t('Error reading wiki'), 'success' => false); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  |  | ||||||
| 		$page = self::load_page($arr); | 		$page = self::load_page($arr); | ||||||
|  |  | ||||||
| 		if($page) { | 		if($page) { | ||||||
|   | |||||||
| @@ -619,23 +619,23 @@ class Wiki extends \Zotlabs\Web\Controller { | |||||||
| 			} | 			} | ||||||
| 			// Determine if observer has permission to rename pages | 			// Determine if observer has permission to rename pages | ||||||
|  |  | ||||||
| 			$perms = Zlib\NativeWikiPage::get_permissions($resource_id, intval($owner['channel_id']), $observer_hash); | 			$perms = Zlib\NativeWiki::get_permissions($resource_id, intval($owner['channel_id']), $observer_hash); | ||||||
| 			if(! $perms['write']) { | 			if(! $perms['write']) { | ||||||
| 				logger('Wiki write permission denied. ' . EOL); | 				logger('Wiki write permission denied. ' . EOL); | ||||||
| 				json_return_and_die(array('success' => false));					 | 				json_return_and_die(array('success' => false));					 | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			$renamed = Zlib\NativeWikiPage::rename_page(array('channel_id' => $owner['channel_id'], 'observer_hash' => $observer_hash, 'resource_id' => $resource_id, 'pageUrlName' => $pageUrlName, 'pageNewName' => $pageNewName)); | 			$renamed = Zlib\NativeWikiPage::rename_page(array('channel_id' => $owner['channel_id'], 'observer_hash' => $observer_hash, 'resource_id' => $resource_id, 'pageUrlName' => $pageUrlName, 'pageNewName' => $pageNewName)); | ||||||
|  |  | ||||||
| 			if($renamed['success']) { | 			if($renamed['success']) { | ||||||
| 				$ob = \App::get_observer(); | 				$ob = \App::get_observer(); | ||||||
| 				$commit = wiki_git_commit(array( | 				$commit = Zlib\NativeWikiPage::commit(array( | ||||||
|  | 					'channel_id' => $owner['channel_id'], | ||||||
| 					'commit_msg' => 'Renamed ' . urldecode($pageUrlName) . ' to ' . $renamed['page']['htmlName'],  | 					'commit_msg' => 'Renamed ' . urldecode($pageUrlName) . ' to ' . $renamed['page']['htmlName'],  | ||||||
| 					'resource_id' => $resource_id,  | 					'resource_id' => $resource_id,  | ||||||
| 					'observer' => $ob, | 					'observer_hash' => $ob['xchan_hash'], | ||||||
| 					'files' => array($pageUrlName . substr($renamed['page']['fileName'], -3), $renamed['page']['fileName']), | 					'pageUrlName' => $pageNewName | ||||||
| 					'all' => true |  | ||||||
| 				)); | 				)); | ||||||
|  |  | ||||||
| 				if($commit['success']) { | 				if($commit['success']) { | ||||||
| 					Zlib\NativeWiki::sync_a_wiki_item($owner['channel_id'],$commit['item_id'],$resource_id); | 					Zlib\NativeWiki::sync_a_wiki_item($owner['channel_id'],$commit['item_id'],$resource_id); | ||||||
| 					json_return_and_die(array('name' => $renamed['page'], 'message' => 'Wiki git repo commit made', 'success' => true)); | 					json_return_and_die(array('name' => $renamed['page'], 'message' => 'Wiki git repo commit made', 'success' => true)); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user