Example #1
0
 /**
  * {@inheritdoc}
  */
 public function transform(File $file, $self = false)
 {
     if ($file->type() !== 'image/jpeg') {
         return $file;
         // Exif only in JPGs
     }
     $width = $file->width();
     $height = $file->height();
     $exif = $file->exif();
     $this->setConfig('degrees', 0);
     // Reset degrees
     $options = array('dest_w' => $width, 'dest_h' => $height, 'source_w' => $width, 'source_h' => $height, 'quality' => $this->getConfig('quality'), 'overwrite' => $self, 'target' => sprintf('%s-exif-%s', $file->name(), $exif['orientation'] ?: 0));
     switch ($exif['orientation']) {
         case 2:
             // Flip horizontally
             $options['source_x'] = $width;
             $options['source_w'] = -$width;
             break;
         case 3:
             // Rotate 180 degrees
             $this->setConfig('degrees', 180);
             break;
         case 4:
         case 5:
         case 7:
             // Flip vertically
             $options['source_y'] = $height;
             $options['source_h'] = -$height;
             // Also rotate -90 degrees for orientation 5
             if ($exif['orientation'] == 5) {
                 $this->setConfig('degrees', -90);
             }
             // Or rotate 90 degrees for orientation 7
             if ($exif['orientation'] == 7) {
                 $this->setConfig('degrees', 90);
             }
             break;
         case 6:
             $this->setConfig('degrees', -90);
             break;
         case 8:
             $this->setConfig('degrees', 90);
             break;
         default:
             // Correct, strip exif only
             break;
     }
     if ($degrees = $this->getConfig('degrees')) {
         $options['postCallback'] = array($this, 'rotate');
     }
     return $this->_process($file, $options);
 }
 /**
  * Transport the file to a remote location.
  *
  * @param \Transit\File $file
  * @return string
  * @throws \Transit\Exception\TransportationException
  */
 public function transport(File $file)
 {
     $config = $this->_config;
     $key = ltrim($config['folder'], '/') . $file->basename();
     $response = null;
     // If larger then 100MB, split upload into parts
     if ($file->size() >= 100 * Size::MB) {
         $uploader = UploadBuilder::newInstance()->setClient($this->getClient())->setSource($file->path())->setBucket($config['bucket'])->setKey($key)->setMinPartSize(10 * Size::MB)->build();
         try {
             $response = $uploader->upload();
         } catch (MultipartUploadException $e) {
             $uploader->abort();
         }
     } else {
         $response = $this->getClient()->putObject(array_filter(array('Key' => $key, 'Bucket' => $config['bucket'], 'Body' => EntityBody::factory(fopen($file->path(), 'r')), 'ACL' => $config['acl'], 'ContentType' => $file->type(), 'ServerSideEncryption' => $config['encryption'], 'StorageClass' => $config['storage'], 'Metadata' => $config['meta'])));
     }
     // Return S3 URL if successful
     if ($response) {
         $file->delete();
         return sprintf('%s/%s/%s', S3Client::getEndpoint($this->getClient()->getDescription(), $config['region'], $config['scheme']), $config['bucket'], $key);
     }
     throw new TransportationException(sprintf('Failed to transport %s to Amazon S3', $file->basename()));
 }
 /**
  * Transform the image using the defined options.
  *
  * @param \Transit\File $file
  * @param array $options
  * @return \Transit\File
  * @throws \DomainException
  */
 protected function _process(File $file, array $options)
 {
     if (!$file->isImage()) {
         throw new DomainException(sprintf('%s is not a valid image', $file->basename()));
     }
     $sourcePath = $file->path();
     $mimeType = $file->type();
     // Create an image to work with
     switch ($mimeType) {
         case 'image/gif':
             $sourceImage = imagecreatefromgif($sourcePath);
             break;
         case 'image/png':
             $sourceImage = imagecreatefrompng($sourcePath);
             break;
         case 'image/jpg':
         case 'image/jpeg':
         case 'image/pjpeg':
             $sourceImage = imagecreatefromjpeg($sourcePath);
             break;
         default:
             throw new DomainException(sprintf('%s can not be transformed', $mimeType));
             break;
     }
     // Gather options
     $options = $options + array('dest_x' => 0, 'dest_y' => 0, 'dest_w' => null, 'dest_h' => null, 'source_x' => 0, 'source_y' => 0, 'source_w' => $file->width(), 'source_h' => $file->height(), 'quality' => 100, 'overwrite' => false, 'target' => '');
     $targetImage = imagecreatetruecolor($options['dest_w'], $options['dest_h']);
     // If gif/png allow transparencies
     if ($mimeType === 'image/gif' || $mimeType === 'image/png') {
         imagealphablending($targetImage, false);
         imagesavealpha($targetImage, true);
         imagefilledrectangle($targetImage, 0, 0, $options['dest_w'], $options['dest_h'], imagecolorallocatealpha($targetImage, 255, 255, 255, 127));
     }
     // Lets take our source and apply it to the temporary file and resize
     imagecopyresampled($targetImage, $sourceImage, $options['dest_x'], $options['dest_y'], $options['source_x'], $options['source_y'], $options['dest_w'], $options['dest_h'], $options['source_w'], $options['source_h']);
     // Now write the transformed image to the server
     if ($options['overwrite']) {
         $options['target'] = $file->name();
     } else {
         if (!$options['target']) {
             $class = explode('\\', get_class($this));
             $class = str_replace('transformer', '', strtolower(end($class)));
             $options['target'] = sprintf('%s-%s-%sx%s', $file->name(), $class, round($options['dest_w']), round($options['dest_h']));
         }
     }
     $targetPath = sprintf('%s%s.%s', $file->dir(), $options['target'], $file->ext());
     switch ($mimeType) {
         case 'image/gif':
             imagegif($targetImage, $targetPath);
             break;
         case 'image/png':
             imagepng($targetImage, $targetPath);
             break;
         case 'image/jpg':
         case 'image/jpeg':
         case 'image/pjpeg':
             imagejpeg($targetImage, $targetPath, $options['quality']);
             break;
     }
     // Clear memory
     imagedestroy($sourceImage);
     imagedestroy($targetImage);
     return new File($targetPath);
 }
Example #4
0
 /**
  * Test for this bug: https://bugs.php.net/bug.php?id=53035
  */
 public function testTypeDetectionForMagicBugs()
 {
     $file = new File(TEMP_DIR . '/magic-mime-verify.js');
     // This will actually return text/plain because magic cant determine a text/javascript file
     // It can also return text/x-c in some weird corner cases
     // If either of these happen, fall back to the extension derived mimetype (or from $_FILES)
     $this->assertEquals('application/javascript', $file->type());
 }