diff options
| -rwxr-xr-x | git-tools/merge.php | 21 | ||||
| -rwxr-xr-x | git-tools/setup_github_network.php | 92 | ||||
| -rw-r--r-- | phpBB/download/file.php | 39 | ||||
| -rw-r--r-- | phpBB/styles/prosilver/template/memberlist_search.html | 4 | 
4 files changed, 118 insertions, 38 deletions
| diff --git a/git-tools/merge.php b/git-tools/merge.php index 41a96c0890..f6142095fb 100755 --- a/git-tools/merge.php +++ b/git-tools/merge.php @@ -124,19 +124,34 @@ function get_repository_url($username, $repository, $ssh = false)  function api_request($query)  { -	$contents = file_get_contents("http://github.com/api/v2/json/$query"); +	return api_url_request("https://api.github.com/$query?per_page=100"); +} + +function api_url_request($url) +{ +	$contents = file_get_contents($url, false, stream_context_create(array( +		'http' => array( +			'header' => "User-Agent: phpBB/1.0\r\n", +		), +	)));  	if ($contents === false)  	{  		throw new RuntimeException("Error: failed to retrieve pull request data\n", 4);  	} +	$contents = json_decode($contents); + +	if (isset($contents->message) && strpos($contents->message, 'API Rate Limit') === 0) +	{ +		throw new RuntimeException('Reached github API Rate Limit. Please try again later' . "\n", 4); +	} -	return json_decode($contents); +	return $contents;  }  function get_pull($username, $repository, $pull_id)  { -	$request = api_request("pulls/$username/$repository/$pull_id"); +	$request = api_request("repos/$username/$repository/pulls/$pull_id");  	$pull = $request->pull; diff --git a/git-tools/setup_github_network.php b/git-tools/setup_github_network.php index 5f2e1609a7..4e144edae6 100755 --- a/git-tools/setup_github_network.php +++ b/git-tools/setup_github_network.php @@ -15,14 +15,14 @@ function show_usage()  	echo "$filename adds repositories of a github network as remotes to a local git repository.\n";  	echo "\n"; -	echo "Usage: [php] $filename -s collaborators|organisation|contributors|network [OPTIONS]\n"; +	echo "Usage: [php] $filename -s collaborators|organisation|contributors|forks [OPTIONS]\n";  	echo "\n";  	echo "Scopes:\n";  	echo "  collaborators                 Repositories of people who have push access to the specified repository\n";  	echo "  contributors                  Repositories of people who have contributed to the specified repository\n";  	echo "  organisation                  Repositories of members of the organisation at github\n"; -	echo "  network                       All repositories of the whole github network\n"; +	echo "  forks                         All repositories of the whole github network\n";  	echo "\n";  	echo "Options:\n"; @@ -55,31 +55,31 @@ exit(work($scope, $username, $repository, $developer));  function work($scope, $username, $repository, $developer)  {  	// Get some basic data -	$network		= get_network($username, $repository); +	$forks		= get_forks($username, $repository);  	$collaborators	= get_collaborators($username, $repository); -	if ($network === false || $collaborators === false) +	if ($forks === false || $collaborators === false)  	{ -		echo "Error: failed to retrieve network or collaborators\n"; +		echo "Error: failed to retrieve forks or collaborators\n";  		return 1;  	}  	switch ($scope)  	{  		case 'collaborators': -			$remotes = array_intersect_key($network, $collaborators); +			$remotes = array_intersect_key($forks, $collaborators);  		break;  		case 'organisation': -			$remotes = array_intersect_key($network, get_organisation_members($username)); +			$remotes = array_intersect_key($forks, get_organisation_members($username));  		break;  		case 'contributors': -			$remotes = array_intersect_key($network, get_contributors($username, $repository)); +			$remotes = array_intersect_key($forks, get_contributors($username, $repository));  		break; -		case 'network': -			$remotes = $network; +		case 'forks': +			$remotes = $forks;  		break;  		default: @@ -145,26 +145,66 @@ function get_repository_url($username, $repository, $ssh = false)  function api_request($query)  { -	$contents = file_get_contents("http://github.com/api/v2/json/$query"); +	return api_url_request("https://api.github.com/$query?per_page=100"); +} + +function api_url_request($url) +{ +	$contents = file_get_contents($url, false, stream_context_create(array( +		'http' => array( +			'header' => "User-Agent: phpBB/1.0\r\n", +		), +	))); + +	$sub_request_result = array(); +	// Check headers for pagination links +	if (!empty($http_response_header)) +	{ +		foreach ($http_response_header as $header_element) +		{ +			// Find Link Header which gives us a link to the next page +			if (strpos($header_element, 'Link: ') === 0) +			{ +				list($head, $header_content) = explode(': ', $header_element); +				foreach (explode(', ', $header_content) as $links) +				{ +					list($url, $rel) = explode('; ', $links); +					if ($rel == 'rel="next"') +					{ +						// Found a next link, follow it and merge the results +						$sub_request_result = api_url_request(substr($url, 1, -1)); +					} +				} +			} +		} +	} +  	if ($contents === false)  	{  		return false;  	} -	return json_decode($contents); +	$contents = json_decode($contents); + +	if (isset($contents->message) && strpos($contents->message, 'API Rate Limit') === 0) +	{ +		throw new RuntimeException('Reached github API Rate Limit. Please try again later' . "\n", 4); +	} + +	return ($sub_request_result) ? array_merge($sub_request_result, $contents) : $contents;  }  function get_contributors($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/contributors"); +	$request = api_request("repos/$username/$repository/stats/contributors");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->contributors as $contributor) +	foreach ($request as $contribution)  	{ -		$usernames[$contributor->login] = $contributor->login; +		$usernames[$contribution->author->login] = $contribution->author->login;  	}  	return $usernames; @@ -172,14 +212,14 @@ function get_contributors($username, $repository)  function get_organisation_members($username)  { -	$request = api_request("organizations/$username/public_members"); +	$request = api_request("orgs/$username/public_members");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->users as $member) +	foreach ($request as $member)  	{  		$usernames[$member->login] = $member->login;  	} @@ -189,35 +229,35 @@ function get_organisation_members($username)  function get_collaborators($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/collaborators"); +	$request = api_request("repos/$username/$repository/collaborators");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->collaborators as $collaborator) +	foreach ($request as $collaborator)  	{ -		$usernames[$collaborator] = $collaborator; +		$usernames[$collaborator->login] = $collaborator->login;  	}  	return $usernames;  } -function get_network($username, $repository) +function get_forks($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/network"); +	$request = api_request("repos/$username/$repository/forks");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->network as $network) +	foreach ($request as $fork)  	{ -		$usernames[$network->owner] = array( -			'username'		=> $network->owner, -			'repository'	=> $network->name, +		$usernames[$fork->owner->login] = array( +			'username'		=> $fork->owner->login, +			'repository'	=> $fork->name,  		);  	} diff --git a/phpBB/download/file.php b/phpBB/download/file.php index 3ceb1ee0cc..22be27c922 100644 --- a/phpBB/download/file.php +++ b/phpBB/download/file.php @@ -285,7 +285,7 @@ else if (($display_cat == ATTACHMENT_CATEGORY_NONE/* || $display_cat == ATTACHME  	$db->sql_query($sql);  } -if ($display_cat == ATTACHMENT_CATEGORY_IMAGE && $mode === 'view' && (strpos($attachment['mimetype'], 'image') === 0) && ((strpos(strtolower($user->browser), 'msie') !== false) && (strpos(strtolower($user->browser), 'msie 8.0') === false))) +if ($display_cat == ATTACHMENT_CATEGORY_IMAGE && $mode === 'view' && (strpos($attachment['mimetype'], 'image') === 0) && (strpos(strtolower($browser), 'msie') !== false) && !phpbb_is_greater_ie_version($user->browser, 7))  {  	wrap_img_in_html(append_sid($phpbb_root_path . 'download/file.' . $phpEx, 'id=' . $attachment['attach_id']), $attachment['real_filename']);  	file_gc(); @@ -343,8 +343,8 @@ function send_avatar_to_browser($file, $browser)  		$image_data = @getimagesize($file_path);  		header('Content-Type: ' . image_type_to_mime_type($image_data[2])); - -		if (strpos(strtolower($browser), 'msie') !== false && strpos(strtolower($browser), 'msie 8.0') === false) +			 +		if ((strpos(strtolower($browser), 'msie') !== false) && !phpbb_is_greater_ie_version($browser, 7))  		{  			header('Content-Disposition: attachment; ' . header_filename($file)); @@ -477,10 +477,9 @@ function send_file_to_browser($attachment, $upload_dir, $category)  	*/  	// Send out the Headers. Do not set Content-Disposition to inline please, it is a security measure for users using the Internet Explorer. -	$is_ie8 = (strpos(strtolower($user->browser), 'msie 8.0') !== false);  	header('Content-Type: ' . $attachment['mimetype']); - -	if ($is_ie8) +		 +	if (phpbb_is_greater_ie_version($user->browser, 7))  	{  		header('X-Content-Type-Options: nosniff');  	} @@ -492,7 +491,7 @@ function send_file_to_browser($attachment, $upload_dir, $category)  	}  	else  	{ -		if (empty($user->browser) || (!$is_ie8 && (strpos(strtolower($user->browser), 'msie') !== false))) +		if (empty($user->browser) || ((strpos(strtolower($user->browser), 'msie') !== false) && !phpbb_is_greater_ie_version($user->browser, 7)))  		{  			header('Content-Disposition: attachment; ' . header_filename(htmlspecialchars_decode($attachment['real_filename'])));  			if (empty($user->browser) || (strpos(strtolower($user->browser), 'msie 6.0') !== false)) @@ -503,7 +502,7 @@ function send_file_to_browser($attachment, $upload_dir, $category)  		else  		{  			header('Content-Disposition: ' . ((strpos($attachment['mimetype'], 'image') === 0) ? 'inline' : 'attachment') . '; ' . header_filename(htmlspecialchars_decode($attachment['real_filename']))); -			if ($is_ie8 && (strpos($attachment['mimetype'], 'image') !== 0)) +			if (phpbb_is_greater_ie_version($user->browser, 7) && (strpos($attachment['mimetype'], 'image') !== 0))  			{  				header('X-Download-Options: noopen');  			} @@ -680,7 +679,8 @@ function set_modified_headers($stamp, $browser)  {  	// let's see if we have to send the file at all  	$last_load 	=  isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) ? strtotime(trim($_SERVER['HTTP_IF_MODIFIED_SINCE'])) : false; -	if ((strpos(strtolower($browser), 'msie 6.0') === false) && (strpos(strtolower($browser), 'msie 8.0') === false)) +		 +	if (strpos(strtolower($browser), 'msie 6.0') === false && !phpbb_is_greater_ie_version($browser, 7))  	{  		if ($last_load !== false && $last_load >= $stamp)  		{ @@ -709,4 +709,25 @@ function file_gc()  	exit;  } +/** +* Check if the browser is internet explorer version 7+ +* +* @param string $user_agent	User agent HTTP header +* @param int $version IE version to check against +* +* @return bool true if internet explorer version is greater than $version +*/ +function phpbb_is_greater_ie_version($user_agent, $version) +{ +	if (preg_match('/msie (\d+)/', strtolower($user_agent), $matches)) +	{ +		$ie_version = (int) $matches[1]; +		return ($ie_version > $version); +	} +	else +	{ +		return false; +	} +} +  ?>
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/memberlist_search.html b/phpBB/styles/prosilver/template/memberlist_search.html index 9df648f644..e6a4bfba97 100644 --- a/phpBB/styles/prosilver/template/memberlist_search.html +++ b/phpBB/styles/prosilver/template/memberlist_search.html @@ -75,6 +75,10 @@ function insert_single(user)  		<dt><label for="msn">{L_MSNM}:</label></dt>  		<dd><input type="text" name="msn" id="msn" value="{MSNM}" class="inputbox" /></dd>  	</dl> +	<dl> +		<dt><label for="jabber">{L_JABBER}:</label></dt> +		<dd><input type="text" name="jabber" id="jabber" value="{JABBER}" class="inputbox" /></dd> +	</dl>  	</fieldset>  	<fieldset class="fields1 column2"> | 
