aboutsummaryrefslogtreecommitdiff
path: root/mod/thewire/actions
diff options
context:
space:
mode:
Diffstat (limited to 'mod/thewire/actions')
-rw-r--r--mod/thewire/actions/add.php63
-rw-r--r--mod/thewire/actions/delete.php38
2 files changed, 101 insertions, 0 deletions
diff --git a/mod/thewire/actions/add.php b/mod/thewire/actions/add.php
new file mode 100644
index 000000000..58589dc9a
--- /dev/null
+++ b/mod/thewire/actions/add.php
@@ -0,0 +1,63 @@
+<?php
+
+ /**
+ * Elgg thewire: add shout action
+ *
+ * @package Elggthewire
+ * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
+ * @author Curverider <info@elgg.com>
+ * @copyright Curverider Ltd 2008-2010
+ * @link http://elgg.org/
+ */
+
+ // Make sure we're logged in (send us to the front page if not)
+ if (!isloggedin()) forward();
+
+ // Get input data
+ $body = get_input('note');
+ $tags = get_input('thewiretags');
+ $access_id = (int)get_default_access();
+ if ($access_id == ACCESS_PRIVATE)
+ $access_id = ACCESS_LOGGED_IN; // Private wire messages are pointless
+ $location = get_input('location');
+ $method = get_input('method');
+ $parent = (int)get_input('parent', 0);
+ if(!$parent)
+ $parent = 0;
+
+ // convert the shout body into tags
+ $tagarray = filter_string($body);
+
+ // Make sure the title / description aren't blank
+ if (empty($body)) {
+ register_error(elgg_echo("thewire:blank"));
+ forward("mod/thewire/add.php");
+
+ // Otherwise, save the thewire post
+ } else {
+
+ if (!thewire_save_post($body, $access_id, $parent, $method)) {
+ register_error(elgg_echo("thewire:error"));
+ if($location == "activity")
+ forward("mod/riverdashboard/");
+ else
+ forward("mod/thewire/add.php");
+ }
+
+ // Now let's add tags. We can pass an array directly to the object property! Easy.
+ if (is_array($tagarray)) {
+ $thewire->tags = $tagarray;
+ }
+
+ // Success message
+ system_message(elgg_echo("thewire:posted"));
+
+ // Forward
+ if($location == "activity")
+ forward("mod/riverdashboard/");
+ else
+ forward("mod/thewire/everyone.php");
+
+ }
+
+?> \ No newline at end of file
diff --git a/mod/thewire/actions/delete.php b/mod/thewire/actions/delete.php
new file mode 100644
index 000000000..60f69d4e7
--- /dev/null
+++ b/mod/thewire/actions/delete.php
@@ -0,0 +1,38 @@
+<?php
+
+ /**
+ * Elgg thewire: delete note action
+ *
+ * @package ElggTheWire
+ * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
+ * @author Curverider <info@elgg.com>
+ * @copyright Curverider Ltd 2008-2010
+ * @link http://elgg.org/
+ */
+
+ // Make sure we're logged in (send us to the front page if not)
+ if (!isloggedin()) forward();
+
+ // Get input data
+ $guid = (int) get_input('thewirepost');
+
+ // Make sure we actually have permission to edit
+ $thewire = get_entity($guid);
+ if ($thewire->getSubtype() == "thewire" && $thewire->canEdit()) {
+
+ // Get owning user
+ $owner = get_entity($thewire->getOwner());
+ // Delete it!
+ $rowsaffected = $thewire->delete();
+ if ($rowsaffected > 0) {
+ // Success message
+ system_message(elgg_echo("thewire:deleted"));
+ } else {
+ register_error(elgg_echo("thewire:notdeleted"));
+ }
+ // Forward to the main wire page
+ forward("mod/thewire/?username=" . $owner->username);
+
+ }
+
+?> \ No newline at end of file