1
votes

I am using the Storage provider to upload files to rackspace like so...

$logo = $request->file('logo');
$content = fopen($logo->getRealPath(), 'r+');

\Storage::disk('cdn')->put('logo.png', $content);

Now, how can I get the url of the file above? I has been looking for a method in the API and it seems so impossible.

3

3 Answers

2
votes

I usually store the disk public URL in the config/filesystems.php file. For example:

    'google' => [
        'driver'        => 's3',
        'key'           => env('STORAGE_GOOGLE_KEY'),
        'secret'        => env('STORAGE_GOOGLE_SECRET'),
        'bucket'        => env('STORAGE_GOOGLE_BUCKET'),
        'base_url'      => 'https://storage.googleapis.com',
        'public_url'    => env('STORAGE_GOOGLE_PUBLIC_URL'),
    ],

Then in my model, I define a mutator for the field containing the file name:

public function getAvatarAttribute($value)
{
    // If avatar isn't a URL, generate it
    if (filter_var($value, FILTER_VALIDATE_URL) !== FALSE) {
        return $value;
    } else {
        $disk = config('filesystems.default');
        return config('filesystems.disks.'.$disk.'.public_url').'/avatars/'.$value;
    }
}

This allows me:

  1. To change the default disk at any time and immediately point all the references to my new disk.
  2. To store actual URLs in the database if required. In my case, avatars may come from OAuth or actual file uploads, so I need to cater for both.
1
votes

The issue here is the way the FlySystem adapter works.

For most operations it will just return a boolean indicating if an operation was successful or not. Even Laravel's FlySystem wrapper also doesn't keep track of paths, so a workaround would be to build the path yourself after a successful upload.

By using the filesystem configuration, we can come up with something like this:

$cdn_url = config('filesystems.disks.cdn.container').'/logo.png';

You get the picture.

0
votes

In recent Laravel releases you can customise your storage URL

https://laravel.com/docs/8.x/filesystem#url-host-customization

URL Host Customization

If you would like to pre-define the host for file URLs generated using the Storage facade, you may add a url option to the disk's configuration array:

'public' => [
    'driver' => 'local',
    'root' => storage_path('app/public'),
    'url' => env('APP_URL').'/storage',
    'visibility' => 'public',
],

example 'url' => 'https://cdn.example.com', or just add it to .env file ( by default for s3 it is AWS_URL)