2017 © Pedro Peláez
 

library resumable-laravel

Laravel compatible PHP package for Resumable uploads

image

vitohe/resumable-laravel

Laravel compatible PHP package for Resumable uploads

  • Wednesday, November 29, 2017
  • by vitohe
  • Repository
  • 0 Watchers
  • 0 Stars
  • 46 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 25 Forks
  • 0 Open issues
  • 8 Versions
  • 0 % Grown

The README.md

PHP backend for resumable.js

This is a fork from dilab/resumable.php with changes to make it compatible with the Laravel Framework, (*1)

It is currently a work in progress and it is currently developed with Laravel versions 5.1 and 5.2 in mind., (*2)

Installation

To install, use composer:, (*3)

composer require black-bits/resumable.js-laravel-backend, (*4)

How to use

app/Http/routes.php, (*5)

<?php

// resumable.js routes
Route::get ('resumable/upload', 'UploadController@resumableUpload');
Route::post('resumable/upload', 'UploadController@resumableUpload');

app/Http/Controllers/UploadController.php, (*6)

<?php
namespace App\Http\Controllers;

use Illuminate\Http\Response;

use Illuminate\Support\Facades\File;

use Dilab\Network\SimpleRequest;
use Dilab\Network\SimpleResponse;
use Dilab\Resumable;

class UploadController extends Controller
{
    /**
     * Handles resumeable uploads via resumable.js
     * 
     * @return Response
     */
    public function resumableUpload()
    {
        $tmpPath    = storage_path().'/tmp';
        $uploadPath = storage_path().'/uploads';
        if(!File::exists($tmpPath)) {
            File::makeDirectory($tmpPath, $mode = 0777, true, true);
        }

        if(!File::exists($uploadPath)) {
            File::makeDirectory($uploadPath, $mode = 0777, true, true);
        }

        $simpleRequest              = new SimpleRequest();
        $simpleResponse             = new SimpleResponse();

        $resumable                  = new Resumable($simpleRequest, $simpleResponse);
        $resumable->tempFolder      = $tmpPath;
        $resumable->uploadFolder    = $uploadPath;


        $result = $resumable->process();

        switch($result) {
            case 200:
                return response([
                    'message' => 'OK',
                ], 200);
                break;
            case 201:
                // mark uploaded file as complete etc
                return response([
                    'message' => 'OK',
                ], 200);
                break;
            case 204:
                return response([
                    'message' => 'Chunk not found',
                ], 204);
                break;
            default:
                return response([
                    'message' => 'An error occurred',
                ], 404);
        }
    }
}

Testing

$ ./vendor/bin/phpunit

The Versions

29/11 2017

dev-master

9999999-dev

Laravel compatible PHP package for Resumable uploads

  Sources   Download

MIT

The Requires

 

The Development Requires

29/11 2017

1.0.4

1.0.4.0

Laravel compatible PHP package for Resumable uploads

  Sources   Download

MIT

The Requires

 

The Development Requires

29/11 2017

0.3.1.x-dev

0.3.1.9999999-dev

Laravel compatible PHP package for Resumable uploads

  Sources   Download

MIT

The Requires

 

The Development Requires

31/01 2016

0.2.1

0.2.1.0

Laravel compatible PHP package for Resumable.js

  Sources   Download

MIT

The Requires

 

The Development Requires

20/01 2016

0.2.0

0.2.0.0

Laravel compatible PHP package for Resumable.js

  Sources   Download

MIT

The Requires

 

The Development Requires

20/12 2015

0.1.2

0.1.2.0

PHP package for Resumable.js

  Sources   Download

MIT

The Requires

 

The Development Requires

11/07 2015

0.1.1

0.1.1.0

PHP package for Resumable.js

  Sources   Download

MIT

The Requires

 

The Development Requires

11/07 2015

0.1.0

0.1.0.0

PHP package for Resumable.js

  Sources   Download

MIT

The Requires

 

The Development Requires