source = $source; } /** * Execute the job. * * @param Client $guzzle * @throws GuzzleException * @throws FileNotFoundException */ public function handle(Client $guzzle) { $response = $guzzle->request('GET', $this->source); //4XX and 5XX responses should get Guzzle to throw an exception, //Laravel should catch and retry these automatically. if ($response->getStatusCode() == '200') { $filesystem = new FileSystem(); $filename = storage_path('HTML') . '/' . $this->createFilenameFromURL($this->source); //backup file first $filenameBackup = $filename . '.' . date('Y-m-d') . '.backup'; if ($filesystem->exists($filename)) { $filesystem->copy($filename, $filenameBackup); } //check if base directory exists if (! $filesystem->exists($filesystem->dirname($filename))) { $filesystem->makeDirectory( $filesystem->dirname($filename), 0755, //mode true //recursive ); } //save new HTML $filesystem->put( $filename, (string) $response->getBody() ); //remove backup if the same if ($filesystem->exists($filenameBackup)) { if ($filesystem->get($filename) == $filesystem->get($filenameBackup)) { $filesystem->delete($filenameBackup); } } } } /** * Create a file path from a URL. This is used when caching the HTML response. * * @param string $url * @return string The path name */ private function createFilenameFromURL(string $url) { $filepath = str_replace(['https://', 'http://'], ['https/', 'http/'], $url); if (substr($filepath, -1) == '/') { $filepath .= 'index.html'; } return $filepath; } }