summaryrefslogtreecommitdiff
path: root/modules/watermark
diff options
context:
space:
mode:
Diffstat (limited to 'modules/watermark')
-rw-r--r--modules/watermark/controllers/admin_watermarks.php47
-rw-r--r--modules/watermark/helpers/watermark.php8
-rw-r--r--modules/watermark/helpers/watermark_installer.php14
-rw-r--r--modules/watermark/models/watermark.php21
-rw-r--r--modules/watermark/views/admin_watermarks.html.php10
5 files changed, 78 insertions, 22 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;
diff --git a/modules/watermark/helpers/watermark.php b/modules/watermark/helpers/watermark.php
index 9fb03ecd..6d8da35a 100644
--- a/modules/watermark/helpers/watermark.php
+++ b/modules/watermark/helpers/watermark.php
@@ -19,14 +19,14 @@
*/
class watermark_Core {
public static function get_watermark_form() {
- $form = new Forge("admin/watermark/load", "", "post",
- array("id" => "gUploadWatermarkForm", "enctype" => "multipart/form-data"));
+ $form = new Forge("admin/watermarks", "", "post");
$group = $form->group("add_watermark")->label(_("Upload Watermark"));
- $group->upload("file")->label(_("Watermark"))->rules("allow[jpg,png,gif],size[1M]");
+ $group->upload("file")->label(_("Watermark"))->rules("allow[jpg,png,gif]|size[1MB]|required");
+ $group->submit(_("Upload"));
return $form;
}
- public static function get_watermark_postion_form($position="southeast") {
+ public static function get_watermark_position_form($position="southeast") {
$form = new Forge("admin/watermark/position", "", "post");
$group = $form->group("watermark_position")->label(_("Update Position"));
$group->dropdown("position")->label(_("Watermark Position"))
diff --git a/modules/watermark/helpers/watermark_installer.php b/modules/watermark/helpers/watermark_installer.php
index e06e52cf..360ac72a 100644
--- a/modules/watermark/helpers/watermark_installer.php
+++ b/modules/watermark/helpers/watermark_installer.php
@@ -22,13 +22,25 @@ class watermark_installer {
$db = Database::instance();
$version = module::get_version("watermark");
if ($version == 0) {
+ $db->query("CREATE TABLE IF NOT EXISTS `watermarks` (
+ `id` int(9) NOT NULL auto_increment,
+ `name` varchar(32) NOT NULL,
+ `width` int(9) NOT NULL,
+ `height` int(9) NOT NULL,
+ `mime_type` varchar(64) default NULL,
+ PRIMARY KEY (`id`),
+ UNIQUE KEY(`name`))
+ ENGINE=InnoDB DEFAULT CHARSET=utf8;");
+
module::set_version("watermark", 1);
- module::set_var("watermark", "watermark_image_path", "");
module::set_var("watermark", "watermark_position", "southeast");
+ @mkdir(VARPATH . "modules/watermark");
}
}
public static function uninstall() {
module::delete("watermark");
+ Database::instance()->query("DROP TABLE `watermarks`");
+ dir::unlink(VARPATH . "modules/watermark");
}
}
diff --git a/modules/watermark/models/watermark.php b/modules/watermark/models/watermark.php
new file mode 100644
index 00000000..b03ce0b7
--- /dev/null
+++ b/modules/watermark/models/watermark.php
@@ -0,0 +1,21 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2008 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class Watermark_Model extends ORM {
+} \ No newline at end of file
diff --git a/modules/watermark/views/admin_watermarks.html.php b/modules/watermark/views/admin_watermarks.html.php
new file mode 100644
index 00000000..3596b73d
--- /dev/null
+++ b/modules/watermark/views/admin_watermarks.html.php
@@ -0,0 +1,10 @@
+<? defined("SYSPATH") or die("No direct script access."); ?>
+<ul class="gWatermarks">
+ <? foreach ($watermarks as $watermark): ?>
+ <li>
+ <img <?= photo::img_dimensions($watermark->width, $watermark->height, 72) ?> src="<?= url::file("var/modules/watermark/$watermark->name") ?>">
+ </li>
+ <? endforeach ?>
+</ul>
+
+<?= $form ?>