Created
March 22, 2022 04:15
-
-
Save defrindr/474caf80c715f2247123eac094dbc22d to your computer and use it in GitHub Desktop.
YII2 Faker image problem vendor/fakerphp/faker/src/Faker/Provider/
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace Faker\Provider; | |
/** | |
* Depends on image generation from http://lorempixel.com/ | |
*/ | |
class Image extends Base | |
{ | |
protected static $categories = array( | |
'abstract', 'animals', 'business', 'cats', 'city', 'food', 'nightlife', | |
'fashion', 'people', 'nature', 'sports', 'technics', 'transport' | |
); | |
/** | |
* Generate the URL that will return a random image | |
* | |
* Set randomize to false to remove the random GET parameter at the end of the url. | |
* | |
* @example 'http://lorempixel.com/640/480/?12345' | |
* | |
* @param integer $width | |
* @param integer $height | |
* @param string|null $category | |
* @param bool $randomize | |
* @param string|null $word | |
* @param bool $gray | |
* | |
* @return string | |
*/ | |
public static function imageUrl($width = 640, $height = 480, $category = null, $randomize = true, $word = null, $gray = false) | |
{ | |
$baseUrl = "https://picsum.photos/"; | |
$url = "{$width}/{$height}/"; | |
if ($gray) { | |
$url .= "?grayscale"; | |
} | |
return $baseUrl . $url; | |
} | |
/** | |
* Download a remote random image to disk and return its location | |
* | |
* Requires curl, or allow_url_fopen to be on in php.ini. | |
* | |
* @example '/path/to/dir/13b73edae8443990be1aa8f1a483bc27.jpg' | |
*/ | |
public static function image($dir = null, $width = 640, $height = 480, $category = null, $fullPath = true, $randomize = true, $word = null, $gray = false) | |
{ | |
$dir = is_null($dir) ? sys_get_temp_dir() : $dir; // GNU/Linux / OS X / Windows compatible | |
// Validate directory path | |
if (!is_dir($dir) || !is_writable($dir)) { | |
throw new \InvalidArgumentException(sprintf('Cannot write to directory "%s"', $dir)); | |
} | |
// Generate a random filename. Use the server address so that a file | |
// generated at the same time on a different server won't have a collision. | |
$name = md5(uniqid(empty($_SERVER['SERVER_ADDR']) ? '' : $_SERVER['SERVER_ADDR'], true)); | |
$filename = $name . '.jpg'; | |
$filepath = $dir . DIRECTORY_SEPARATOR . $filename; | |
$url = static::imageUrl($width, $height, $category, $randomize, $word, $gray); | |
// save file | |
if (function_exists('file_get_contents')) { | |
$image = file_get_contents($url, false, stream_context_create(array( | |
'ssl' => array( | |
'verify_peer' => false, | |
'verify_peer_name' => false, | |
'allow_self_signed' => true | |
) | |
))); | |
if ($image) { | |
file_put_contents($filepath, $image); | |
} else { | |
return false; | |
} | |
} elseif (ini_get('allow_url_fopen')) { | |
// use remote fopen() via copy() | |
$success = copy($url, $filepath); | |
} else { | |
return new \RuntimeException('The image formatter downloads an image from a remote HTTP server. Therefore, it requires that PHP can request remote hosts, either via cURL or fopen()'); | |
} | |
return $fullPath ? $filepath : $filename; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment