summaryrefslogtreecommitdiff
path: root/modules/watermark/controllers
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2008-12-23 01:29:17 +0000
committerBharat Mediratta <bharat@menalto.com>2008-12-23 01:29:17 +0000
commitddcf10dfce923fd07192e7dbc39fa34de3e22be8 (patch)
tree4d5f47c777390a37f155ef0cb9c5abfa922bf20e /modules/watermark/controllers
parentf476e2169ee84922dfe48d5a5065e1eabe40713f (diff)
Allow the site admin to upload watermark images. Can't do much with them yet.
Diffstat (limited to 'modules/watermark/controllers')
-rw-r--r--modules/watermark/controllers/admin_watermarks.php47
1 files changed, 30 insertions, 17 deletions
diff --git a/modules/watermark/controllers/admin_watermarks.php b/modules/watermark/controllers/admin_watermarks.php
index ef984e24..972e506e 100644
--- a/modules/watermark/controllers/admin_watermarks.php
+++ b/modules/watermark/controllers/admin_watermarks.php
@@ -18,31 +18,44 @@
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
class Admin_Watermarks_Controller extends Admin_Controller {
- public function load() {
+ public function index() {
$form = watermark::get_watermark_form();
- Kohana::log("debug", print_r($form, 1));
- if ($form->validate()) {
- $file = $_POST["file"];
- Kohana::log("debug", $file);
-
- $pathinfo = pathinfo($file);
- $watermark_target = $pathinfo["basename"];
- if (copy($file, VARPATH . $watermark_target)) {
- module::set_var("watermark", "watermark_image_path", $watermark_target);
- unlink($file);
- $form->success = _("Watermark saved");
+ if (request::method() == "post" && $form->validate()) {
+ $file = $_POST["file"];
+ $pathinfo = pathinfo($file);
+ $name = $pathinfo["basename"];
+ if (ORM::factory("watermark")->where("name", $name)->count_all() > 0) {
+ message::add(_("There is already a watermark with that name"), log::WARNING);
+ } else if (!($image_info = getimagesize($file))) {
+ message::add(_("An error occurred while saving this watermark"), log::WARNING);
+ } else {
+ if (empty($pathinfo["extension"])) {
+ $name .= "." . image_type_to_extension($image_info[2]);
+ }
+ if (!rename($file, VARPATH . "modules/watermark/$name")) {
+ message::add(_("An error occurred while saving this watermark"), log::WARNING);
} else {
- // @todo set and error message
+ $watermark = ORM::factory("watermark");
+ $watermark->name = $name;
+ $watermark->width = $image_info[0];
+ $watermark->height = $image_info[1];
+ $watermark->mime_type = $image_info["mime"];
+ $watermark->save();
+ message::add(_("Watermark saved"));
+ url::redirect("admin/watermarks");
}
+ }
+ @unlink($file);
}
- print $form;
+ $view = new View("admin_watermarks.html");
+ $view->watermarks = ORM::factory("watermark")->find_all();
+ $view->form = watermark::get_watermark_form();
+ return $view;
}
public function get_form($user_id) {
try {
- // @todo check for admin user
-
$path = module::get_var("watermark", "watermark_image_path");
$view = new View("watermark_position.html");
@@ -55,7 +68,7 @@ class Admin_Watermarks_Controller extends Admin_Controller {
->find_all(1, 0)->current();
// @todo determine what to do if water mark is not set
- // @todo caclulate the view sizes
+ // @todo calculate the view sizes
$view->sample_image = $photo->resize_url();
$scaleWidth = $photo->resize_width / $photo->width;
$scaleHeight = $photo->resize_height / $photo->height;