summaryrefslogtreecommitdiff
path: root/actions
diff options
context:
space:
mode:
authorRobin Millette <millette@controlyourself.ca>2009-05-27 03:47:45 -0400
committerRobin Millette <millette@controlyourself.ca>2009-05-27 03:47:45 -0400
commited1e1d9f440acfbb99c7a6e3d2b5c11fdcfa27ce (patch)
treee4362570dc97ad2b3e50ba2bc01749af5b09745d /actions
parent37423b12d7a58bae728476c6f1a8ff3fef4c6d9f (diff)
Handles local aliases (redirection) for file uploads attached to notices.
Diffstat (limited to 'actions')
-rw-r--r--actions/file.php40
-rw-r--r--actions/newnotice.php15
2 files changed, 50 insertions, 5 deletions
diff --git a/actions/file.php b/actions/file.php
new file mode 100644
index 000000000..1179dbe9a
--- /dev/null
+++ b/actions/file.php
@@ -0,0 +1,40 @@
+<?php
+/*
+ * Laconica - a distributed open-source microblogging tool
+ * Copyright (C) 2008, Controlez-Vous, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 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 Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+if (!defined('LACONICA')) { exit(1); }
+
+require_once(INSTALLDIR.'/actions/shownotice.php');
+
+class FileAction extends ShowNoticeAction
+{
+ function showPage() {
+ $source_url = common_local_url('file', array('notice' => $this->notice->id));
+ $query = "select file_redirection.url as url from file join file_redirection on file.id = file_redirection.file_id where file.url = '$source_url'";
+ $file = new File_redirection;
+ $file->query($query);
+ $file->fetch();
+ if (empty($file->url)) {
+ die('nothing attached here');
+ } else {
+ header("Location: {$file->url}");
+ die();
+ }
+ }
+}
+
diff --git a/actions/newnotice.php b/actions/newnotice.php
index d7507c118..aebdab3cc 100644
--- a/actions/newnotice.php
+++ b/actions/newnotice.php
@@ -110,7 +110,7 @@ class NewnoticeAction extends Action
}
function isFileAttached() {
- return $_FILES['attach']['error'] === UPLOAD_ERR_OK;
+ return isset($_FILES['attach']['error']) && ($_FILES['attach']['error'] === UPLOAD_ERR_OK);
}
/**
@@ -205,14 +205,19 @@ class NewnoticeAction extends Action
$destination = "file/{$notice->id}-$filename";
if (move_uploaded_file($_FILES['attach']['tmp_name'], INSTALLDIR . "/$destination")) {
$file = new File;
-// $file->url = common_local_url('file', array('notice' => $notice->id));
- $file->url = common_path($destination);
+ $file->url = common_local_url('file', array('notice' => $notice->id));
+// $file->url = common_path($destination);
$file->size = filesize(INSTALLDIR . "/$destination");
$file->date = time();
$file->mimetype = $_FILES['attach']['type'];
- if ($ok = $file->insert()) {
+ if ($file_id = $file->insert()) {
+ $file_redir = new File_redirection;
+ $file_redir->url = common_path($destination);
+ $file_redir->file_id = $file_id;
+ $file_redir->insert();
+
$f2p = new File_to_post;
- $f2p->file_id = $ok;
+ $f2p->file_id = $file_id;
$f2p->post_id = $notice->id;
$f2p->insert();
} else {