| @@ -48,7 +48,7 @@ | ||
| 48 | 48 | $tmpFile = tempname(sys_get_temp_dir(), 'ct'); | 
| 49 | 49 | file_put_contents($tmpFile, $obj['Body']); | 
| 50 | 50 | $mime = trim((new CommandExecuter($this->cpeLogger))->execute( | 
| 51 | - 'file -b --mime-type ' . escapeshellarg($tmpFile))['out']); | |
| 51 | + 'file -b --mime-type '.escapeshellarg($tmpFile))['out']); | |
| 52 | 52 | $type = substr($mime, 0, strpos($mime, '/')); | 
| 53 | 53 | |
| 54 | 54 | $this->cpeLogger->log_out( | 
| @@ -8,9 +8,6 @@ | ||
| 8 | 8 | |
| 9 | 9 | require_once __DIR__.'/BasicActivity.php'; | 
| 10 | 10 | |
| 11 | -use Guzzle\Http\EntityBody; | |
| 12 | -use SA\CpeSdk; | |
| 13 | - | |
| 14 | 11 | class ValidateAssetActivity extends BasicActivity | 
| 15 | 12 |  { | 
| 16 | 13 | /** @var \finfo */ | 
| @@ -1,6 +1,6 @@ | ||
| 1 | 1 | <?php | 
| 2 | 2 | |
| 3 | -require_once __DIR__ . '/BasicTranscoder.php'; | |
| 3 | +require_once __DIR__.'/BasicTranscoder.php'; | |
| 4 | 4 | |
| 5 | 5 | class AudioTranscoder extends BasicTranscoder | 
| 6 | 6 |  { | 
| @@ -4,13 +4,13 @@ discard block | ||
| 4 | 4 | * Script used to get a file in AWS S3 | 
| 5 | 5 | **/ | 
| 6 | 6 | |
| 7 | -require __DIR__ . "/../../vendor/autoload.php"; | |
| 7 | +require __DIR__."/../../vendor/autoload.php"; | |
| 8 | 8 | |
| 9 | 9 | use Aws\S3\S3Client; | 
| 10 | 10 | |
| 11 | 11 | function usage() | 
| 12 | 12 |  { | 
| 13 | -    echo("Usage: php ". basename(__FILE__) . " [-h] [--force] --bucket <s3 bucket> --file <filename> --to <filepath>\n"); | |
| 13 | +    echo("Usage: php ".basename(__FILE__)." [-h] [--force] --bucket <s3 bucket> --file <filename> --to <filepath>\n"); | |
| 14 | 14 |      echo("--help, -h: Print this help\n"); | 
| 15 | 15 |      echo("--bucket <s3 bucket>: Name of the S3 bucket\n"); | 
| 16 | 16 |      echo("--file <filename>: Name of the file in the S3 bucket\n"); | 
| @@ -41,8 +41,8 @@ discard block | ||
| 41 | 41 | file_exists($options['to']) && | 
| 42 | 42 | filesize($options['to'])) | 
| 43 | 43 |  { | 
| 44 | - print json_encode([ "status" => "SUCCESS", | |
| 45 | - "msg" => "[".__FILE__."] Using local copy: '" . $options['to'] . "'" ]); | |
| 44 | + print json_encode(["status" => "SUCCESS", | |
| 45 | + "msg" => "[".__FILE__."] Using local copy: '".$options['to']."'"]); | |
| 46 | 46 | exit(0); | 
| 47 | 47 | } | 
| 48 | 48 | |
| @@ -58,14 +58,14 @@ discard block | ||
| 58 | 58 | )); | 
| 59 | 59 | |
| 60 | 60 | // Print JSON error output | 
| 61 | - print json_encode([ "status" => "SUCCESS", | |
| 62 | - "msg" => "[".__FILE__."] Download '" . $options['bucket'] . "/" . $options['file'] . "' successful !" ]); | |
| 61 | + print json_encode(["status" => "SUCCESS", | |
| 62 | + "msg" => "[".__FILE__."] Download '".$options['bucket']."/".$options['file']."' successful !"]); | |
| 63 | 63 | } | 
| 64 | 64 |  catch (Exception $e) { | 
| 65 | - $err = "Unable to get '" . $options['bucket'] . "/" . $options['file'] . "' file from S3 ! " . $e->getMessage(); | |
| 65 | + $err = "Unable to get '".$options['bucket']."/".$options['file']."' file from S3 ! ".$e->getMessage(); | |
| 66 | 66 | // Print JSON error output | 
| 67 | - print json_encode([ "status" => "ERROR", | |
| 68 | - "msg" => "[".__FILE__."] $err" ]); | |
| 67 | + print json_encode(["status" => "ERROR", | |
| 68 | + "msg" => "[".__FILE__."] $err"]); | |
| 69 | 69 | |
| 70 | 70 |      die("[".__FILE__."] $err"); | 
| 71 | 71 | } | 
| @@ -22,8 +22,9 @@ discard block | ||
| 22 | 22 | function check_input_parameters($options) | 
| 23 | 23 |  { | 
| 24 | 24 | if (!count($options) || isset($options['h']) || | 
| 25 | - isset($options['help'])) | |
| 26 | - usage(); | |
| 25 | +        isset($options['help'])) { | |
| 26 | + usage(); | |
| 27 | + } | |
| 27 | 28 | |
| 28 | 29 | if (!isset($options['bucket']) || !isset($options['file']) || | 
| 29 | 30 | !isset($options['to'])) | 
| @@ -60,8 +61,7 @@ discard block | ||
| 60 | 61 | // Print JSON error output | 
| 61 | 62 | print json_encode([ "status" => "SUCCESS", | 
| 62 | 63 | "msg" => "[".__FILE__."] Download '" . $options['bucket'] . "/" . $options['file'] . "' successful !" ]); | 
| 63 | -} | |
| 64 | -catch (Exception $e) { | |
| 64 | +} catch (Exception $e) { | |
| 65 | 65 | $err = "Unable to get '" . $options['bucket'] . "/" . $options['file'] . "' file from S3 ! " . $e->getMessage(); | 
| 66 | 66 | // Print JSON error output | 
| 67 | 67 | print json_encode([ "status" => "ERROR", | 
| @@ -4,13 +4,13 @@ discard block | ||
| 4 | 4 | * Script used to put a file in AWS S3 | 
| 5 | 5 | **/ | 
| 6 | 6 | |
| 7 | -require __DIR__ . "/../../vendor/autoload.php"; | |
| 7 | +require __DIR__."/../../vendor/autoload.php"; | |
| 8 | 8 | |
| 9 | 9 | use Aws\S3\S3Client; | 
| 10 | 10 | |
| 11 | 11 | function usage() | 
| 12 | 12 |  { | 
| 13 | -    echo("Usage: php ". basename(__FILE__) . " [-h] [--rrs::] [--encrypt::] --bucket <s3 bucket> --file <filename> --from <filepath>\n"); | |
| 13 | +    echo("Usage: php ".basename(__FILE__)." [-h] [--rrs::] [--encrypt::] --bucket <s3 bucket> --file <filename> --from <filepath>\n"); | |
| 14 | 14 |      echo("--help, -h: Print this help\n"); | 
| 15 | 15 |      echo("--bucket <s3 bucket>: Name of the S3 bucket\n"); | 
| 16 | 16 |      echo("--file <filename>: Name of the file to create in bucket. You can override local filename.\n"); | 
| @@ -33,7 +33,7 @@ discard block | ||
| 33 | 33 | usage(); | 
| 34 | 34 | } | 
| 35 | 35 | |
| 36 | - $options['bucket'] = rtrim( $options['bucket'], "/"); | |
| 36 | + $options['bucket'] = rtrim($options['bucket'], "/"); | |
| 37 | 37 | } | 
| 38 | 38 | |
| 39 | 39 |  $options = getopt("h", [ | 
| @@ -66,15 +66,15 @@ discard block | ||
| 66 | 66 | $s3->putObject($params); | 
| 67 | 67 | |
| 68 | 68 | // Print JSON error output | 
| 69 | - print json_encode([ "status" => "SUCCESS", | |
| 70 | - "msg" => "[".__FILE__."] Upload '" . $options['from'] . "' to '" . $options['bucket'] . "/" . $options['file'] . "' successful !" ]); | |
| 69 | + print json_encode(["status" => "SUCCESS", | |
| 70 | + "msg" => "[".__FILE__."] Upload '".$options['from']."' to '".$options['bucket']."/".$options['file']."' successful !"]); | |
| 71 | 71 | } | 
| 72 | 72 |  catch (Exception $e) { | 
| 73 | - $err = "Unable to put file '" . $options['from'] . "' into S3: '" . $options['bucket'] . "/" . $options['file'] . "'! " . $e->getMessage(); | |
| 73 | + $err = "Unable to put file '".$options['from']."' into S3: '".$options['bucket']."/".$options['file']."'! ".$e->getMessage(); | |
| 74 | 74 | |
| 75 | 75 | // Print JSON error output | 
| 76 | - print json_encode([ "status" => "ERROR", | |
| 77 | - "msg" => "[".__FILE__."] $err" ]); | |
| 76 | + print json_encode(["status" => "ERROR", | |
| 77 | + "msg" => "[".__FILE__."] $err"]); | |
| 78 | 78 | |
| 79 | 79 |      die("[".__FILE__."] $err"); | 
| 80 | 80 | } | 
| @@ -23,8 +23,9 @@ discard block | ||
| 23 | 23 | function check_input_parameters(&$options) | 
| 24 | 24 |  { | 
| 25 | 25 | if (!count($options) || isset($options['h']) || | 
| 26 | - isset($options['help'])) | |
| 27 | - usage(); | |
| 26 | +        isset($options['help'])) { | |
| 27 | + usage(); | |
| 28 | + } | |
| 28 | 29 | |
| 29 | 30 | if (!isset($options['bucket']) || !isset($options['file']) || | 
| 30 | 31 | !isset($options['from'])) | 
| @@ -57,10 +58,12 @@ discard block | ||
| 57 | 58 | ); | 
| 58 | 59 | |
| 59 | 60 | // StorageClass and Encryption ? | 
| 60 | - if (isset($options['rrs'])) | |
| 61 | - $params['StorageClass'] = 'REDUCED_REDUNDANCY'; | |
| 62 | - if (isset($options['encrypt'])) | |
| 63 | - $params['ServerSideEncryption'] = 'AES256'; | |
| 61 | +    if (isset($options['rrs'])) { | |
| 62 | + $params['StorageClass'] = 'REDUCED_REDUNDANCY'; | |
| 63 | + } | |
| 64 | +    if (isset($options['encrypt'])) { | |
| 65 | + $params['ServerSideEncryption'] = 'AES256'; | |
| 66 | + } | |
| 64 | 67 | |
| 65 | 68 | // Upload and Save file to S3 | 
| 66 | 69 | $s3->putObject($params); | 
| @@ -68,8 +71,7 @@ discard block | ||
| 68 | 71 | // Print JSON error output | 
| 69 | 72 | print json_encode([ "status" => "SUCCESS", | 
| 70 | 73 | "msg" => "[".__FILE__."] Upload '" . $options['from'] . "' to '" . $options['bucket'] . "/" . $options['file'] . "' successful !" ]); | 
| 71 | -} | |
| 72 | -catch (Exception $e) { | |
| 74 | +} catch (Exception $e) { | |
| 73 | 75 | $err = "Unable to put file '" . $options['from'] . "' into S3: '" . $options['bucket'] . "/" . $options['file'] . "'! " . $e->getMessage(); | 
| 74 | 76 | |
| 75 | 77 | // Print JSON error output | 
| @@ -17,8 +17,9 @@ discard block | ||
| 17 | 17 | |
| 18 | 18 | public function __construct($cpeLogger = null) | 
| 19 | 19 |      { | 
| 20 | - if (!$cpeLogger) | |
| 21 | - $this->cpeLogger = new CpeSdk\CpeLogger(null, 'CommandExecuter'); | |
| 20 | +        if (!$cpeLogger) { | |
| 21 | + $this->cpeLogger = new CpeSdk\CpeLogger(null, 'CommandExecuter'); | |
| 22 | + } | |
| 22 | 23 | $this->cpeLogger = $cpeLogger; | 
| 23 | 24 | } | 
| 24 | 25 | |
| @@ -112,10 +113,12 @@ discard block | ||
| 112 | 113 | if ($procStatus['exitcode'] > 0) | 
| 113 | 114 |          { | 
| 114 | 115 |              $this->cpeLogger->log_out("ERROR", basename(__FILE__), "Can't execute: $cmd. Exit Code: ".$procStatus['exitcode']); | 
| 115 | - if ($allOut) | |
| 116 | -                $this->cpeLogger->log_out("ERROR", basename(__FILE__), "COMMAND STDOUT: ".$allOut); | |
| 117 | - if ($allOutErr) | |
| 118 | -                $this->cpeLogger->log_out("ERROR", basename(__FILE__), "COMMAND STDERR: ".$allOutErr); | |
| 116 | +            if ($allOut) { | |
| 117 | +                            $this->cpeLogger->log_out("ERROR", basename(__FILE__), "COMMAND STDOUT: ".$allOut); | |
| 118 | + } | |
| 119 | +            if ($allOutErr) { | |
| 120 | +                            $this->cpeLogger->log_out("ERROR", basename(__FILE__), "COMMAND STDERR: ".$allOutErr); | |
| 121 | + } | |
| 119 | 122 | } | 
| 120 | 123 | |
| 121 | 124 |          if ($showProgress) { | 
| @@ -1,9 +1,9 @@ discard block | ||
| 1 | 1 | <?php | 
| 2 | 2 | /** | 
| 3 | - * This class allows you to call the two S3 scripts | |
| 4 | - * to download and upload files. | |
| 5 | - * The scripts are executed using the CommandExecuter | |
| 6 | - */ | |
| 3 | + * This class allows you to call the two S3 scripts | |
| 4 | + * to download and upload files. | |
| 5 | + * The scripts are executed using the CommandExecuter | |
| 6 | + */ | |
| 7 | 7 | |
| 8 | 8 | require_once __DIR__ . '/CommandExecuter.php'; | 
| 9 | 9 | |
| @@ -85,7 +85,7 @@ discard block | ||
| 85 | 85 | $cmd, | 
| 86 | 86 | 2, | 
| 87 | 87 |              array(1 => array("pipe", "w"), | 
| 88 | -                  2 => array("pipe", "w")), | |
| 88 | +                    2 => array("pipe", "w")), | |
| 89 | 89 | $callback, | 
| 90 | 90 | $callbackParams, | 
| 91 | 91 | true, | 
| @@ -5,7 +5,7 @@ discard block | ||
| 5 | 5 | * The scripts are executed using the CommandExecuter | 
| 6 | 6 | */ | 
| 7 | 7 | |
| 8 | -require_once __DIR__ . '/CommandExecuter.php'; | |
| 8 | +require_once __DIR__.'/CommandExecuter.php'; | |
| 9 | 9 | |
| 10 | 10 | use SA\CpeSdk; | 
| 11 | 11 | |
| @@ -35,7 +35,7 @@ discard block | ||
| 35 | 35 | $callback = null, | 
| 36 | 36 | $callbackParams = null) | 
| 37 | 37 |      {    | 
| 38 | - $cmd = "php " . __DIR__ . self::GET_FROM_S3; | |
| 38 | + $cmd = "php ".__DIR__.self::GET_FROM_S3; | |
| 39 | 39 | $cmd .= " --bucket $bucket"; | 
| 40 | 40 | $cmd .= " --file $filename"; | 
| 41 | 41 | $cmd .= " --to $saveFileTo"; | 
| @@ -57,7 +57,7 @@ discard block | ||
| 57 | 57 | $callback = null, | 
| 58 | 58 | $callbackParams = null) | 
| 59 | 59 |      { | 
| 60 | - $cmd = "php " . __DIR__ . self::PUT_IN_S3; | |
| 60 | + $cmd = "php ".__DIR__.self::PUT_IN_S3; | |
| 61 | 61 | $cmd .= " --bucket $bucket"; | 
| 62 | 62 | $cmd .= " --file $filename"; | 
| 63 | 63 | $cmd .= " --from $pathToFileToSend"; | 
| @@ -22,8 +22,9 @@ discard block | ||
| 22 | 22 | |
| 23 | 23 | public function __construct($cpeLogger = null) | 
| 24 | 24 |      { | 
| 25 | - if (!$cpeLogger) | |
| 26 | - $this->cpeLogger = new CpeSdk\CpeLogger(null, 'S3Utils'); | |
| 25 | +        if (!$cpeLogger) { | |
| 26 | + $this->cpeLogger = new CpeSdk\CpeLogger(null, 'S3Utils'); | |
| 27 | + } | |
| 27 | 28 | $this->cpeLogger = $cpeLogger; | 
| 28 | 29 | } | 
| 29 | 30 | |
| @@ -61,10 +62,12 @@ discard block | ||
| 61 | 62 | $cmd .= " --bucket $bucket"; | 
| 62 | 63 | $cmd .= " --file $filename"; | 
| 63 | 64 | $cmd .= " --from $pathToFileToSend"; | 
| 64 | - if ($options['rrs']) | |
| 65 | - $cmd .= " --rrs"; | |
| 66 | - if ($options['encrypt']) | |
| 67 | - $cmd .= " --encrypt"; | |
| 65 | +        if ($options['rrs']) { | |
| 66 | + $cmd .= " --rrs"; | |
| 67 | + } | |
| 68 | +        if ($options['encrypt']) { | |
| 69 | + $cmd .= " --encrypt"; | |
| 70 | + } | |
| 68 | 71 | |
| 69 | 72 | // HAndle execution | 
| 70 | 73 | return ($this->handle_s3_ops( | 
| @@ -91,21 +94,25 @@ discard block | ||
| 91 | 94 | true, | 
| 92 | 95 | 5); | 
| 93 | 96 | |
| 94 | - if ($out['outErr']) | |
| 95 | - throw new CpeSdk\CpeException($out['outErr'], | |
| 97 | +        if ($out['outErr']) { | |
| 98 | + throw new CpeSdk\CpeException($out['outErr'], | |
| 96 | 99 | self::S3_OPS_FAILED); | 
| 100 | + } | |
| 97 | 101 | |
| 98 | - if (!$out['out']) | |
| 99 | -            throw new CpeSdk\CpeException("Script '$caller' didn't return any data !", | |
| 102 | +        if (!$out['out']) { | |
| 103 | +                    throw new CpeSdk\CpeException("Script '$caller' didn't return any data !", | |
| 100 | 104 | self::NO_OUTPUT_DATA); | 
| 105 | + } | |
| 101 | 106 | |
| 102 | - if (!($decoded = json_decode($out['out'], true))) | |
| 103 | - throw new CpeSdk\CpeException($out['out'], | |
| 107 | +        if (!($decoded = json_decode($out['out'], true))) { | |
| 108 | + throw new CpeSdk\CpeException($out['out'], | |
| 104 | 109 | self::S3_OPS_FAILED); | 
| 110 | + } | |
| 105 | 111 | |
| 106 | - if ($decoded["status"] == "ERROR") | |
| 107 | - throw new CpeSdk\CpeException($decoded["msg"], | |
| 112 | +        if ($decoded["status"] == "ERROR") { | |
| 113 | + throw new CpeSdk\CpeException($decoded["msg"], | |
| 108 | 114 | self::S3_OPS_FAILED); | 
| 115 | + } | |
| 109 | 116 | |
| 110 | 117 | return ($decoded); | 
| 111 | 118 | } | 
| @@ -7,7 +7,7 @@ discard block | ||
| 7 | 7 | * We use ffprobe, ffmpeg and convert to analyse, transcode and manipulate videos and images (watermark) | 
| 8 | 8 | */ | 
| 9 | 9 | |
| 10 | -require_once __DIR__ . '/BasicTranscoder.php'; | |
| 10 | +require_once __DIR__.'/BasicTranscoder.php'; | |
| 11 | 11 | |
| 12 | 12 | use SA\CpeSdk; | 
| 13 | 13 | |
| @@ -105,7 +105,7 @@ discard block | ||
| 105 | 105 | $this->cpeLogger->log_out( | 
| 106 | 106 | "INFO", | 
| 107 | 107 | basename(__FILE__), | 
| 108 | - "Input Video metadata: " . print_r($metadata, true), | |
| 108 | + "Input Video metadata: ".print_r($metadata, true), | |
| 109 | 109 | $this->activityLogKey | 
| 110 | 110 | ); | 
| 111 | 111 | |
| @@ -142,7 +142,7 @@ discard block | ||
| 142 | 142 | $this->cpeLogger->log_out( | 
| 143 | 143 | "ERROR", | 
| 144 | 144 | basename(__FILE__), | 
| 145 | - "Execution of command '".$ffmpegCmd."' failed: " . print_r($metadata, true). ". ".$e->getMessage(), | |
| 145 | + "Execution of command '".$ffmpegCmd."' failed: ".print_r($metadata, true).". ".$e->getMessage(), | |
| 146 | 146 | $this->activityLogKey | 
| 147 | 147 | ); | 
| 148 | 148 | return false; | 
| @@ -185,7 +185,7 @@ discard block | ||
| 185 | 185 | } | 
| 186 | 186 | |
| 187 | 187 | // Append output filename to path | 
| 188 | -        $pathToOutputFiles .= "/" . $outputWanted->{'output_file_info'}['basename']; | |
| 188 | +        $pathToOutputFiles .= "/".$outputWanted->{'output_file_info'}['basename']; | |
| 189 | 189 |          // Replace ${output_file} by output filename and path to local disk | 
| 190 | 190 |          $ffmpegCmd = preg_replace('/\$\{output_file\}/', $pathToOutputFiles, $ffmpegCmd); | 
| 191 | 191 | |
| @@ -245,7 +245,7 @@ discard block | ||
| 245 | 245 | } | 
| 246 | 246 | |
| 247 | 247 | // Create FFMpeg arguments | 
| 248 | - $ffmpegArgs = " -i $pathToInputFile -y -threads 0"; | |
| 248 | + $ffmpegArgs = " -i $pathToInputFile -y -threads 0"; | |
| 249 | 249 | $ffmpegArgs .= " -s $size"; | 
| 250 | 250 | $ffmpegArgs .= " -vcodec $videoCodec"; | 
| 251 | 251 | $ffmpegArgs .= " -acodec $audioCodec"; | 
| @@ -256,9 +256,9 @@ discard block | ||
| 256 | 256 | $ffmpegArgs .= " $watermarkOptions"; | 
| 257 | 257 | |
| 258 | 258 | // Append output filename to path | 
| 259 | -        $pathToOutputFiles .= "/" . $outputWanted->{'output_file_info'}['basename']; | |
| 259 | +        $pathToOutputFiles .= "/".$outputWanted->{'output_file_info'}['basename']; | |
| 260 | 260 | // Final command | 
| 261 | - $ffmpegCmd = "ffmpeg $ffmpegArgs $pathToOutputFiles"; | |
| 261 | + $ffmpegCmd = "ffmpeg $ffmpegArgs $pathToOutputFiles"; | |
| 262 | 262 | |
| 263 | 263 | return ($ffmpegCmd); | 
| 264 | 264 | } | 
| @@ -285,8 +285,8 @@ discard block | ||
| 285 | 285 |                  $snapshot_sec = $outputWanted->{'snapshot_sec'}; | 
| 286 | 286 | } | 
| 287 | 287 | |
| 288 | -            $time = gmdate("H:i:s", $snapshot_sec) . ".000"; | |
| 289 | - $pathToOutputFiles .= "/" . $outputFileInfo['basename']; | |
| 288 | +            $time = gmdate("H:i:s", $snapshot_sec).".000"; | |
| 289 | + $pathToOutputFiles .= "/".$outputFileInfo['basename']; | |
| 290 | 290 | $frameOptions = " -ss $time -vframes 1"; | 
| 291 | 291 | } | 
| 292 | 292 |          else if ($outputWanted->{'mode'} == 'intervals') | 
| @@ -297,14 +297,14 @@ discard block | ||
| 297 | 297 |                  $intervals = $outputWanted->{'intervals'}; | 
| 298 | 298 | } | 
| 299 | 299 | |
| 300 | - $pathToOutputFiles .= "/" . $outputFileInfo['filename'] . "%06d." | |
| 300 | + $pathToOutputFiles .= "/".$outputFileInfo['filename']."%06d." | |
| 301 | 301 | . $outputFileInfo['extension']; | 
| 302 | 302 | $frameOptions = " -vf fps=fps=1/$intervals"; | 
| 303 | 303 | } | 
| 304 | 304 | |
| 305 | 305 | // Create FFMpeg arguments | 
| 306 | - $ffmpegArgs = " -i $pathToInputFile -y -threads 0"; | |
| 307 | -        $ffmpegArgs .= " -vf scale=" . $outputWanted->{'size'}; | |
| 306 | + $ffmpegArgs = " -i $pathToInputFile -y -threads 0"; | |
| 307 | +        $ffmpegArgs .= " -vf scale=".$outputWanted->{'size'}; | |
| 308 | 308 | $ffmpegArgs .= " $frameOptions -f image2 -q:v 8"; | 
| 309 | 309 | |
| 310 | 310 | // Final command | 
| @@ -335,7 +335,7 @@ discard block | ||
| 335 | 335 | $this->activityLogKey); | 
| 336 | 336 | |
| 337 | 337 | // Transform watermark for opacity | 
| 338 | -        $convertCmd = "convert $watermarkPath -alpha on -channel A -evaluate Multiply " . $watermarkOptions->{'opacity'} . " +channel $newWatermarkPath"; | |
| 338 | +        $convertCmd = "convert $watermarkPath -alpha on -channel A -evaluate Multiply ".$watermarkOptions->{'opacity'}." +channel $newWatermarkPath"; | |
| 339 | 339 | |
| 340 | 340 |          try { | 
| 341 | 341 | $out = $this->executer->execute($convertCmd, 1, | 
| @@ -364,7 +364,7 @@ discard block | ||
| 364 | 364 | // Format options for FFMpeg | 
| 365 | 365 |          $size      = $watermarkOptions->{'size'}; | 
| 366 | 366 | $positions = $this->get_watermark_position($watermarkOptions); | 
| 367 | - $formattedOptions = "-vf \"movie=$newWatermarkPath, scale=$size [wm]; [in][wm] overlay=" . $positions['x'] . ':' . $positions['y'] . " [out]\""; | |
| 367 | + $formattedOptions = "-vf \"movie=$newWatermarkPath, scale=$size [wm]; [in][wm] overlay=".$positions['x'].':'.$positions['y']." [out]\""; | |
| 368 | 368 | |
| 369 | 369 | return ($formattedOptions); | 
| 370 | 370 | } | 
| @@ -381,10 +381,10 @@ discard block | ||
| 381 | 381 |              $positions['y'] = $watermarkOptions->{'y'}; | 
| 382 | 382 | } | 
| 383 | 383 |          if ($watermarkOptions->{'x'} < 0) { | 
| 384 | -            $positions['x'] = 'main_w-overlay_w' . $watermarkOptions->{'x'}; | |
| 384 | +            $positions['x'] = 'main_w-overlay_w'.$watermarkOptions->{'x'}; | |
| 385 | 385 | } | 
| 386 | 386 |          if ($watermarkOptions->{'y'} < 0) { | 
| 387 | -            $positions['y'] = 'main_h-overlay_h' . $watermarkOptions->{'y'}; | |
| 387 | +            $positions['y'] = 'main_h-overlay_h'.$watermarkOptions->{'y'}; | |
| 388 | 388 | } | 
| 389 | 389 | |
| 390 | 390 | return ($positions); | 
| @@ -493,7 +493,7 @@ discard block | ||
| 493 | 493 | // # finally, progress is easy | 
| 494 | 494 | $progress = 0; | 
| 495 | 495 |          if ($done) { | 
| 496 | - $progress = round(($done/$duration)*100); | |
| 496 | + $progress = round(($done / $duration) * 100); | |
| 497 | 497 | } | 
| 498 | 498 | |
| 499 | 499 | $this->cpeLogger->log_out( | 
| @@ -528,7 +528,7 @@ discard block | ||
| 528 | 528 | } | 
| 529 | 529 | |
| 530 | 530 |          $preset     = $output_wanted->{"preset"}; | 
| 531 | - $presetPath = __DIR__ . '/../../../presets/'; | |
| 531 | + $presetPath = __DIR__.'/../../../presets/'; | |
| 532 | 532 | |
| 533 | 533 |          if (!($presetContent = file_get_contents($presetPath.$preset.".json"))) { | 
| 534 | 534 |              throw new CpeSdk\CpeException("Can't open preset file !", | 
| @@ -552,7 +552,7 @@ discard block | ||
| 552 | 552 | } | 
| 553 | 553 | |
| 554 | 554 |          $preset     = $output->{"preset"}; | 
| 555 | - $presetPath = __DIR__ . '/../../../presets/'; | |
| 555 | + $presetPath = __DIR__.'/../../../presets/'; | |
| 556 | 556 | |
| 557 | 557 |          if (!($files = scandir($presetPath))) { | 
| 558 | 558 |              throw new CpeSdk\CpeException("Unable to open preset directory '$presetPath' !", | 
| @@ -608,22 +608,22 @@ discard block | ||
| 608 | 608 | } | 
| 609 | 609 | |
| 610 | 610 | $analyse = [ | 
| 611 | - 'duration' => isset($metadata->format->duration) ? (float)$metadata->format->duration : 0, | |
| 611 | + 'duration' => isset($metadata->format->duration) ? (float) $metadata->format->duration : 0, | |
| 612 | 612 | 'video' => empty($videoStreams) ? null : [ | 
| 613 | 613 | 'codec' => $videoStreams->codec_name, | 
| 614 | 614 | 'color' => $videoStreams->color_space, | 
| 615 | - 'resolution' => $videoStreams->width . 'x' . $videoStreams->height, | |
| 615 | + 'resolution' => $videoStreams->width.'x'.$videoStreams->height, | |
| 616 | 616 | 'sar' => $videoStreams->sample_aspect_ratio, | 
| 617 | 617 | 'dar' => $videoStreams->display_aspect_ratio, | 
| 618 | 618 | 'framerate' => $videoStreams->r_frame_rate, | 
| 619 | - 'bitrate' => isset($videoStreams->bit_rate) ? (int)$videoStreams->bit_rate : null | |
| 619 | + 'bitrate' => isset($videoStreams->bit_rate) ? (int) $videoStreams->bit_rate : null | |
| 620 | 620 | ], | 
| 621 | 621 | 'audio' => empty($audioStreams) ? null : [ | 
| 622 | 622 | 'codec' => $audioStreams->codec_name, | 
| 623 | 623 | 'frequency' => $audioStreams->sample_rate, | 
| 624 | - 'channels' => (int)$audioStreams->channels, | |
| 624 | + 'channels' => (int) $audioStreams->channels, | |
| 625 | 625 | 'depth' => $audioStreams->bits_per_sample, | 
| 626 | - 'bitrate' => (int)$audioStreams->bit_rate | |
| 626 | + 'bitrate' => (int) $audioStreams->bit_rate | |
| 627 | 627 | ] | 
| 628 | 628 | ]; | 
| 629 | 629 | |
| @@ -40,6 +40,12 @@ | ||
| 40 | 40 | // $metadata should contain the ffprobe video stream array. | 
| 41 | 41 | |
| 42 | 42 | // Start FFmpeg for output transcoding | 
| 43 | + | |
| 44 | + /** | |
| 45 | + * @param string $tmpPathInput | |
| 46 | + * @param null|string $pathToInputFile | |
| 47 | + * @param string $pathToOutputFiles | |
| 48 | + */ | |
| 43 | 49 | public function transcode_asset( | 
| 44 | 50 | $tmpPathInput, | 
| 45 | 51 | $pathToInputFile, | 
| @@ -65,13 +65,14 @@ discard block | ||
| 65 | 65 | $this->activityLogKey | 
| 66 | 66 | ); | 
| 67 | 67 | |
| 68 | - if ($metadata) | |
| 69 | - $this->cpeLogger->log_out( | |
| 68 | +        if ($metadata) { | |
| 69 | + $this->cpeLogger->log_out( | |
| 70 | 70 | "INFO", | 
| 71 | 71 | basename(__FILE__), | 
| 72 | 72 | "Input Video metadata: " . print_r($metadata, true), | 
| 73 | 73 | $this->activityLogKey | 
| 74 | 74 | ); | 
| 75 | + } | |
| 75 | 76 | |
| 76 | 77 |          try { | 
| 77 | 78 | $ffmpegCmd = ""; | 
| @@ -138,8 +139,7 @@ discard block | ||
| 138 | 139 | // FFProbe the output file and return its information | 
| 139 | 140 | $output_info = | 
| 140 | 141 |                  $this->get_asset_info($pathToOutputFiles."/".$outputWanted->{'output_file_info'}['basename']); | 
| 141 | - } | |
| 142 | -        catch (\Exception $e) { | |
| 142 | +        } catch (\Exception $e) { | |
| 143 | 143 | $this->cpeLogger->log_out( | 
| 144 | 144 | "ERROR", | 
| 145 | 145 | basename(__FILE__), | 
| @@ -289,8 +289,7 @@ discard block | ||
| 289 | 289 |              $time = gmdate("H:i:s", $snapshot_sec) . ".000"; | 
| 290 | 290 | $pathToOutputFiles .= "/" . $outputFileInfo['basename']; | 
| 291 | 291 | $frameOptions = " -ss $time -vframes 1"; | 
| 292 | - } | |
| 293 | -        else if ($outputWanted->{'mode'} == 'intervals') | |
| 292 | +        } else if ($outputWanted->{'mode'} == 'intervals') | |
| 294 | 293 |          { | 
| 295 | 294 | $intervals = self::INTERVALS_DEFAULT; | 
| 296 | 295 |              if (isset($outputWanted->{'intervals'}) && | 
| @@ -343,8 +342,7 @@ discard block | ||
| 343 | 342 |                  array(1 => array("pipe", "w"), 2 => array("pipe", "w")), | 
| 344 | 343 | false, false, | 
| 345 | 344 | false, 1); | 
| 346 | - } | |
| 347 | -        catch (\Exception $e) { | |
| 345 | +        } catch (\Exception $e) { | |
| 348 | 346 | $this->cpeLogger->log_out( | 
| 349 | 347 | "ERROR", | 
| 350 | 348 | basename(__FILE__), | 
| @@ -604,8 +602,7 @@ discard block | ||
| 604 | 602 |          foreach ($metadata->streams as $key => $value) { | 
| 605 | 603 |              if ($value->codec_type === 'video') { | 
| 606 | 604 | $videoStreams = $value; | 
| 607 | - } | |
| 608 | -            else if ($value->codec_type === 'audio') { | |
| 605 | +            } else if ($value->codec_type === 'audio') { | |
| 609 | 606 | $audioStreams = $value; | 
| 610 | 607 | } | 
| 611 | 608 | } | 
| @@ -21,6 +21,12 @@ | ||
| 21 | 21 | // $metadata should contain the ffprobe video stream array. | 
| 22 | 22 | |
| 23 | 23 | // Start FFmpeg for output transcoding | 
| 24 | + | |
| 25 | + /** | |
| 26 | + * @param string $tmpPathInput | |
| 27 | + * @param null|string $pathToInputFile | |
| 28 | + * @param string $pathToOutputFiles | |
| 29 | + */ | |
| 24 | 30 | public function transcode_asset( | 
| 25 | 31 | $tmpPathInput, | 
| 26 | 32 | $pathToInputFile, | 
| @@ -44,7 +44,7 @@ discard block | ||
| 44 | 44 | $this->cpeLogger->log_out( | 
| 45 | 45 | "INFO", | 
| 46 | 46 | basename(__FILE__), | 
| 47 | - "Input Video metadata: " . print_r($metadata, true), | |
| 47 | + "Input Video metadata: ".print_r($metadata, true), | |
| 48 | 48 | $this->activityLogKey | 
| 49 | 49 | ); | 
| 50 | 50 | |
| @@ -117,7 +117,7 @@ discard block | ||
| 117 | 117 | $this->cpeLogger->log_out( | 
| 118 | 118 | "ERROR", | 
| 119 | 119 | basename(__FILE__), | 
| 120 | - "Execution of command '".$convertCmd."' failed: " . print_r($metadata, true). ". ".$e->getMessage(), | |
| 120 | + "Execution of command '".$convertCmd."' failed: ".print_r($metadata, true).". ".$e->getMessage(), | |
| 121 | 121 | $this->activityLogKey | 
| 122 | 122 | ); | 
| 123 | 123 | return false; | 
| @@ -161,7 +161,7 @@ discard block | ||
| 161 | 161 | |
| 162 | 162 | // Append output filename to path | 
| 163 | 163 | $pathToOutputFiles .= | 
| 164 | -            "/" . $outputWanted->{'output_file_info'}['basename']; | |
| 164 | +            "/".$outputWanted->{'output_file_info'}['basename']; | |
| 165 | 165 | |
| 166 | 166 | $convertCmd = "convert $convertArgs $pathToOutputFiles"; | 
| 167 | 167 | |
| @@ -184,7 +184,7 @@ discard block | ||
| 184 | 184 | $pathToInputFile, $convertCmd); | 
| 185 | 185 | |
| 186 | 186 | // Append output filename to path | 
| 187 | -        $pathToOutputFiles .= "/" . $outputWanted->{'output_file_info'}['basename']; | |
| 187 | +        $pathToOutputFiles .= "/".$outputWanted->{'output_file_info'}['basename']; | |
| 188 | 188 |          // Replace ${output_file} by output filename and path to local disk | 
| 189 | 189 |          $convertCmd = preg_replace('/\$\{output_file\}/', | 
| 190 | 190 | $pathToOutputFiles, $convertCmd); | 
| @@ -40,13 +40,14 @@ discard block | ||
| 40 | 40 | $this->activityLogKey | 
| 41 | 41 | ); | 
| 42 | 42 | |
| 43 | - if ($metadata) | |
| 44 | - $this->cpeLogger->log_out( | |
| 43 | +        if ($metadata) { | |
| 44 | + $this->cpeLogger->log_out( | |
| 45 | 45 | "INFO", | 
| 46 | 46 | basename(__FILE__), | 
| 47 | 47 | "Input Video metadata: " . print_r($metadata, true), | 
| 48 | 48 | $this->activityLogKey | 
| 49 | 49 | ); | 
| 50 | + } | |
| 50 | 51 | |
| 51 | 52 |          try { | 
| 52 | 53 | $convertCmd = ""; | 
| @@ -67,8 +68,7 @@ discard block | ||
| 67 | 68 | $metadata, | 
| 68 | 69 | $outputWanted | 
| 69 | 70 | ); | 
| 70 | - } | |
| 71 | -            else { | |
| 71 | +            } else { | |
| 72 | 72 | $convertCmd = $this->craft_convert_cmd( | 
| 73 | 73 | $tmpPathInput, | 
| 74 | 74 | $pathToInputFile, | 
| @@ -112,8 +112,7 @@ discard block | ||
| 112 | 112 | // FFProbe the output file and return its information | 
| 113 | 113 | $output_info = | 
| 114 | 114 |                  $this->get_asset_info($pathToOutputFiles."/".$outputWanted->{'output_file_info'}['basename']); | 
| 115 | - } | |
| 116 | -        catch (\Exception $e) { | |
| 115 | +        } catch (\Exception $e) { | |
| 117 | 116 | $this->cpeLogger->log_out( | 
| 118 | 117 | "ERROR", | 
| 119 | 118 | basename(__FILE__), | 
| @@ -67,8 +67,9 @@ discard block | ||
| 67 | 67 | |
| 68 | 68 | # If we have metadata, we expect the output of ffprobe | 
| 69 | 69 | $metadata = null; | 
| 70 | -            if (isset($this->input->{'input_asset_metadata'}))  | |
| 71 | -                $metadata = $this->input->{'input_asset_metadata'}; | |
| 70 | +            if (isset($this->input->{'input_asset_metadata'})) { | |
| 71 | +                            $metadata = $this->input->{'input_asset_metadata'}; | |
| 72 | + } | |
| 72 | 73 | |
| 73 | 74 | // Perform transcoding | 
| 74 | 75 | $result = $videoTranscoder->transcode_asset( | 
| @@ -90,8 +91,9 @@ discard block | ||
| 90 | 91 | |
| 91 | 92 | # If we have metadata, we expect the output of ffprobe | 
| 92 | 93 | $metadata = null; | 
| 93 | -            if (isset($this->input->{'input_asset_metadata'}))  | |
| 94 | -                $metadata = $this->input->{'input_asset_metadata'}; | |
| 94 | +            if (isset($this->input->{'input_asset_metadata'})) { | |
| 95 | +                            $metadata = $this->input->{'input_asset_metadata'}; | |
| 96 | + } | |
| 95 | 97 | |
| 96 | 98 | // Perform transcoding | 
| 97 | 99 | $result = $imageTranscoder->transcode_asset( | 
| @@ -194,16 +196,18 @@ discard block | ||
| 194 | 196 | |
| 195 | 197 | if (!file_exists($this->pathToOutputFiles)) | 
| 196 | 198 |          { | 
| 197 | - if ($this->debug) | |
| 198 | -                $this->cpeLogger->log_out("INFO", basename(__FILE__),  | |
| 199 | +            if ($this->debug) { | |
| 200 | +                            $this->cpeLogger->log_out("INFO", basename(__FILE__),  | |
| 199 | 201 | "Creating TMP output folder '".$this->pathToOutputFiles."'", | 
| 200 | 202 | $this->activityLogKey); | 
| 203 | + } | |
| 201 | 204 | |
| 202 | - if (!mkdir($this->pathToOutputFiles, 0750, true)) | |
| 203 | - throw new CpeSdk\CpeException( | |
| 205 | +            if (!mkdir($this->pathToOutputFiles, 0750, true)) { | |
| 206 | + throw new CpeSdk\CpeException( | |
| 204 | 207 | "Unable to create temporary folder '$this->pathToOutputFiles' !", | 
| 205 | 208 | self::TMP_FOLDER_FAIL | 
| 206 | 209 | ); | 
| 210 | + } | |
| 207 | 211 | } | 
| 208 | 212 | } | 
| 209 | 213 | |