protected function save(waRequestFile $file) { $product_id = waRequest::post('product_id', null, waRequest::TYPE_INT); $product_model = new shopProductModel(); if (!$product_model->checkRights($product_id)) { throw new waException(_w("Access denied")); } // check image if (!($image = $file->waImage())) { throw new waException('Incorrect image'); } $image_changed = false; /** * Extend upload proccess * Make extra workup * @event image_upload */ $event = wa()->event('image_upload', $image); if ($event) { foreach ($event as $plugin_id => $result) { if ($result) { $image_changed = true; } } } if (!$this->model) { $this->model = new shopProductImagesModel(); } $data = array('product_id' => $product_id, 'upload_datetime' => date('Y-m-d H:i:s'), 'width' => $image->width, 'height' => $image->height, 'size' => $file->size, 'original_filename' => basename($file->name), 'ext' => $file->extension); $image_id = $data['id'] = $this->model->add($data); if (!$image_id) { throw new waException("Database error"); } /** * @var shopConfig $config */ $config = $this->getConfig(); $image_path = shopImage::getPath($data); if (file_exists($image_path) && !is_writable($image_path) || !file_exists($image_path) && !waFiles::create($image_path)) { $this->model->deleteById($image_id); throw new waException(sprintf("The insufficient file write permissions for the %s folder.", substr($image_path, strlen($config->getRootPath())))); } if ($image_changed) { $image->save($image_path); // save original $original_file = shopImage::getOriginalPath($data); if ($config->getOption('image_save_original') && $original_file) { $file->moveTo($original_file); } } else { $file->moveTo($image_path); } unset($image); // free variable shopImage::generateThumbs($data, $config->getImageSizes()); return array('id' => $image_id, 'name' => $file->name, 'type' => $file->type, 'size' => $file->size, 'url_thumb' => shopImage::getUrl($data, $config->getImageSize('thumb')), 'url_crop' => shopImage::getUrl($data, $config->getImageSize('crop')), 'url_crop_small' => shopImage::getUrl($data, $config->getImageSize('crop_small')), 'description' => ''); }
protected function save(waRequestFile $f) { if (file_exists($this->path . DIRECTORY_SEPARATOR . $f->name)) { $i = strrpos($f->name, '.'); $name = urlencode(substr($f->name, 0, $i)); $ext = substr($f->name, $i + 1); $i = 1; while (file_exists($this->path . DIRECTORY_SEPARATOR . $name . '-' . $i . '.' . $ext)) { $i++; } $this->name = $name . '-' . $i . '.' . $ext; return $f->moveTo($this->path, $this->name); } return $f->moveTo($this->path, $f->name); }
protected function save(waRequestFile $f) { $name = $f->name; if (!preg_match('//u', $name)) { $tmp_name = @iconv('windows-1251', 'utf-8//ignore', $name); if ($tmp_name) { $name = $tmp_name; } } return $f->moveTo($this->path, $name); }
protected function save(waRequestFile $file) { if (!$this->model) { $this->model = new shopProductSkusModel(); } $field = array('id' => waRequest::post('sku_id', null, waRequest::TYPE_INT), 'product_id' => waRequest::post('product_id', null, waRequest::TYPE_INT)); $data = array('file_size' => $file->size, 'file_name' => $file->name); $this->model->updateByField($field, $data); $file_path = shopProduct::getPath($field['product_id'], "sku_file/{$field['id']}." . pathinfo($file->name, PATHINFO_EXTENSION)); if (file_exists($file_path) && !is_writable($file_path) || !file_exists($file_path) && !waFiles::create($file_path)) { $data = array('file_size' => 0, 'file_name' => ''); $this->model->updateByField($field, $data); throw new waException(sprintf("The insufficient file write permissions for the %s folder.", substr($file_path, strlen($this->getConfig()->getRootPath())))); } $file->moveTo($file_path); return array('name' => $file->name, 'size' => waFiles::formatSize($file->size)); }
protected function save(waRequestFile $file) { // check image if (!($image = $file->waImage())) { throw new waException(_w('Incorrect image')); } $exif_data = photosExif::getInfo($file->tmp_name); $image_changed = false; if (!empty($exif_data['Orientation'])) { $image_changed = $this->correctOrientation($exif_data['Orientation'], $image); } /** * Extend upload proccess * Make extra workup * @event photo_upload */ $event = wa()->event('photo_upload', $image); if ($event && !$image_changed) { foreach ($event as $plugin_id => $result) { if ($result) { $image_changed = true; break; } } } $data = array('name' => preg_replace('/\\.[^\\.]+$/', '', basename($file->name)), 'ext' => $file->extension, 'size' => $file->size, 'type' => $image->type, 'width' => $image->width, 'height' => $image->height, 'contact_id' => $this->getUser()->getId(), 'status' => $this->status, 'upload_datetime' => date('Y-m-d H:i:s')); if ($this->status <= 0) { $data['hash'] = md5(uniqid(time(), true)); } $photo_id = $data['id'] = $this->model->insert($data); if (!$photo_id) { throw new waException(_w('Database error')); } // update url $url = $this->generateUrl($data['name'], $photo_id); $this->model->updateById($photo_id, array('url' => $url)); // check rigths to upload folder $photo_path = photosPhoto::getPhotoPath($data); if (file_exists($photo_path) && !is_writable($photo_path) || !file_exists($photo_path) && !waFiles::create($photo_path)) { $this->model->deleteById($photo_id); throw new waException(sprintf(_w("The insufficient file write permissions for the %s folder."), substr($photo_path, strlen($this->getConfig()->getRootPath())))); } if ($image_changed) { $image->save($photo_path); // save original if ($this->getConfig()->getOption('save_original')) { $original_file = photosPhoto::getOriginalPhotoPath($photo_path); $file->moveTo($original_file); } } else { $file->moveTo($photo_path); } unset($image); // free variable // add to album if ($photo_id && $this->album_id) { $album_photos_model = new photosAlbumPhotosModel(); // update note if album is empty and note is yet null $r = $album_photos_model->getByField('album_id', $this->album_id); if (!$r) { $album_model = new photosAlbumModel(); $sql = "UPDATE " . $album_model->getTableName() . " SET note = IFNULL(note, s:note) WHERE id = i:album_id"; $time = !empty($exif_data['DateTimeOriginal']) ? strtotime($exif_data['DateTimeOriginal']) : time(); $album_model->query($sql, array('note' => mb_strtolower(_ws(date('F', $time))) . ' ' . _ws(date('Y', $time)), 'album_id' => $this->album_id)); } // add to album iteself $sort = (int) $album_photos_model->query("SELECT sort + 1 AS sort FROM " . $album_photos_model->getTableName() . " WHERE album_id = i:album_id ORDER BY sort DESC LIMIT 1", array('album_id' => $this->album_id))->fetchField('sort'); $album_photos_model->insert(array('photo_id' => $photo_id, 'album_id' => $this->album_id, 'sort' => $sort)); } // save rights for groups if ($this->groups) { $rights_model = new photosPhotoRightsModel(); $rights_model->multiInsert(array('photo_id' => $photo_id, 'group_id' => $this->groups)); } // save exif data if (!empty($exif_data)) { $exif_model = new photosPhotoExifModel(); $exif_model->save($photo_id, $exif_data); } $sizes = $this->getConfig()->getSizes(); photosPhoto::generateThumbs($data, $sizes); return array('name' => $file->name, 'type' => $file->type, 'size' => $file->size, 'thumbnail_url' => photosPhoto::getPhotoUrl($data, photosPhoto::getThumbPhotoSize()), 'url' => '#/photo/' . $photo_id . '/'); }
protected function save(waRequestFile $file) { $path = wa()->getTempPath('csv/upload/'); waFiles::create($path); $original_name = $file->name; if ($name = tempnam($path, 'csv')) { unlink($name); if (($ext = pathinfo($original_name, PATHINFO_EXTENSION)) && preg_match('/^\\w+$/', $ext)) { $name .= '.' . $ext; } $file->moveTo($name); } else { throw new waException(_w('Error file upload')); } $encoding = waRequest::post('encoding', 'UTF-8'); $delimiter = waRequest::post('delimiter'); try { $this->reader = new shopCsvReader($name, $delimiter, $encoding); $delimiters = array(';', ',', 'tab'); $used_delimiters = array($delimiter); while (count($this->reader->header()) < 2 && ($delimiter = array_diff($delimiters, $used_delimiters))) { $delimiter = reset($delimiter); $used_delimiters[] = $delimiter; $this->reader->delete(); $this->reader = new shopCsvReader($name, $delimiter, $encoding); } if (count($this->reader->header()) < 2) { $this->reader->delete(); $delimiter = waRequest::post('delimiter'); $this->reader = new shopCsvReader($name, $delimiter, $encoding); } $encodings = array('UTF-8', 'Windows-1251', 'ISO-8859-1'); $used_encodings = array($encoding); while (in_array(false, (array) $this->reader->header(), true) && ($encoding = array_diff($encodings, $used_encodings))) { $encoding = reset($encoding); $used_encodings[] = $encoding; $this->reader->delete(); $this->reader = new shopCsvReader($name, $delimiter, $encoding); } if (in_array(false, (array) $this->reader->header(), true) || count($this->reader->header()) < 2) { throw new waException($this->reader->header() ? _w('No data columns were located in the uploaded file. Make sure right separator and encoding were chosen for this upload.') : _w('Unsupported CSV file structure')); } $profile_helper = new shopImportexportHelper('csv:product:import'); $profile = $profile_helper->getConfig(); $profile['config'] += array('encoding' => $encoding, 'delimiter' => ';', 'map' => array()); $params = array(); $params['id'] = 'csvproducts'; $params['title_wrapper'] = '%s'; $params['description_wrapper'] = '<br><span class="hint">%s</span>'; $params['control_wrapper'] = '<div class="field"><div class="name">%s</div><div class="value">%s %s</div></div>'; $params['options'] = $this->options(); $control = true ? shopCsvReader::TABLE_CONTROL : shopCsvReader::MAP_CONTROL; switch ($control) { case shopCsvReader::TABLE_CONTROL: $params['preview'] = 50; $params['columns'] = array(array('shopCsvProductviewController', 'tableRowHandler'), ' '); $params['control_wrapper'] = '<div class="field"><div class="value" style="overflow-x:auto;margin-left:0;">%s %s</div></div>'; $params['title_wrapper'] = false; $params['row_handler'] = 'csv_product/rows/'; $params['row_handler_string'] = true; $params['autocomplete_handler'] = 'csv_product/autocomplete/reset/'; break; case shopCsvReader::MAP_CONTROL: default: $control = shopCsvReader::MAP_CONTROL; break; } return array('name' => htmlentities(basename($this->reader->file()), ENT_QUOTES, 'utf-8'), 'original_name' => htmlentities(basename($original_name), ENT_QUOTES, 'utf-8'), 'size' => waFiles::formatSize($this->reader->size()), 'original_size' => waFiles::formatSize($file->size), 'controls' => waHtmlControl::getControl($control, 'csv_map', $params), 'control' => $control, 'header' => $this->reader->header(), 'columns_offset' => count(ifset($params['columns'], array())), 'delimiter' => $delimiter, 'encoding' => $encoding); } catch (waException $ex) { if ($this->reader) { $this->reader->delete(true); } throw $ex; } }
protected function save(waRequestFile $f) { return $f->moveTo($this->path, $f->name); }
protected function saveFile(waRequestFile $f, $path, &$name) { $name = $f->name; if (!preg_match('//u', $name)) { $tmp_name = @iconv('windows-1251', 'utf-8//ignore', $name); if ($tmp_name) { $name = $tmp_name; } } if (file_exists($path . DIRECTORY_SEPARATOR . $name)) { $i = strrpos($name, '.'); $ext = substr($name, $i + 1); $name = substr($name, 0, $i); $i = 1; while (file_exists($path . DIRECTORY_SEPARATOR . $name . '-' . $i . '.' . $ext)) { $i++; } $name = $name . '-' . $i . '.' . $ext; } return $f->moveTo($path, $name); }