mirror of
https://github.com/Pathduck/gallery3.git
synced 2026-05-20 03:19:13 -04:00
Also whitelist the digibug controller so that it's accessible when the gallery is private, and don't expire old proxies right away since Digibug may request the full size multiple times for different preview operations. Fixes ticket #1410.
119 lines
4.0 KiB
PHP
119 lines
4.0 KiB
PHP
<?php defined("SYSPATH") or die("No direct script access.");
|
|
/**
|
|
* Gallery - a web based photo album viewer and editor
|
|
* Copyright (C) 2000-2010 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 Digibug_Controller extends Controller {
|
|
public function print_photo($id) {
|
|
access::verify_csrf();
|
|
$item = ORM::factory("item", $id);
|
|
access::required("view", $item);
|
|
|
|
if (access::group_can(identity::everybody(), "view_full", $item)) {
|
|
$full_url = $item->file_url(true);
|
|
$thumb_url = $item->thumb_url(true);
|
|
} else {
|
|
$proxy = ORM::factory("digibug_proxy");
|
|
$proxy->uuid = md5(rand());
|
|
$proxy->item_id = $item->id;
|
|
$proxy->save();
|
|
$full_url = url::abs_site("digibug/print_proxy/full/$proxy->uuid");
|
|
$thumb_url = url::abs_site("digibug/print_proxy/thumb/$proxy->uuid");
|
|
}
|
|
|
|
$v = new View("digibug_form.html");
|
|
$v->order_params = array(
|
|
"digibug_api_version" => "100",
|
|
"company_id" => module::get_var("digibug", "company_id"),
|
|
"event_id" => module::get_var("digibug", "event_id"),
|
|
"cmd" => "addimg",
|
|
"partner_code" => "69",
|
|
"return_url" => url::abs_site("digibug/close_window"),
|
|
"num_images" => "1",
|
|
"image_1" => $full_url,
|
|
"thumb_1" => $thumb_url,
|
|
"image_height_1" => $item->height,
|
|
"image_width_1" => $item->width,
|
|
"thumb_height_1" => $item->thumb_height,
|
|
"thumb_width_1" => $item->thumb_width,
|
|
"title_1" => html::purify($item->title));
|
|
|
|
print $v;
|
|
}
|
|
|
|
public function print_proxy($type, $uuid) {
|
|
// If its a request for the full size then make sure we are coming from an
|
|
// authorized address
|
|
if ($type == "full") {
|
|
$remote_addr = ip2long(Input::instance()->server("REMOTE_ADDR"));
|
|
if ($remote_addr === false) {
|
|
throw new Kohana_404_Exception();
|
|
}
|
|
$config = Kohana::config("digibug");
|
|
|
|
$authorized = false;
|
|
foreach ($config["ranges"] as $ip_range) {
|
|
$low = ip2long($ip_range["low"]);
|
|
$high = ip2long($ip_range["high"]);
|
|
$authorized = $low !== false && $high !== false &&
|
|
$low <= $remote_addr && $remote_addr <= $high;
|
|
if ($authorized) {
|
|
break;
|
|
}
|
|
}
|
|
if (!$authorized) {
|
|
throw new Kohana_404_Exception();
|
|
}
|
|
}
|
|
|
|
$proxy = ORM::factory("digibug_proxy")->where("uuid", "=", $uuid)->find();
|
|
if (!$proxy->loaded() || !$proxy->item->loaded()) {
|
|
throw new Kohana_404_Exception();
|
|
}
|
|
|
|
$file = $type == "full" ? $proxy->item->file_path() : $proxy->item->thumb_path();
|
|
if (!file_exists($file)) {
|
|
throw new Kohana_404_Exception();
|
|
}
|
|
|
|
// We don't need to save the session for this request
|
|
Session::instance()->abort_save();
|
|
|
|
if (!TEST_MODE) {
|
|
// Dump out the image
|
|
header("Content-Type: {$proxy->item->mime_type}");
|
|
Kohana::close_buffers(false);
|
|
$fd = fopen($file, "rb");
|
|
fpassthru($fd);
|
|
fclose($fd);
|
|
}
|
|
|
|
$this->_clean_expired();
|
|
}
|
|
|
|
public function close_window() {
|
|
print "<script type=\"text/javascript\">window.close();</script>";
|
|
}
|
|
|
|
private function _clean_expired() {
|
|
db::build()
|
|
->delete("digibug_proxies")
|
|
->where("request_date", "<=", new Database_Expression("(CURDATE() - INTERVAL 10 DAY)"))
|
|
->limit(20)
|
|
->execute();
|
|
}
|
|
} |