summaryrefslogtreecommitdiff
path: root/modules/gallery/helpers/gallery_rest.php
blob: 82d1bb5be5659c62d238be4e9c0ca82a0d6ce9a4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php defined("SYSPATH") or die("No direct script access.");
/**
 * Gallery - a web based photo album viewer and editor
 * Copyright (C) 2000-2009 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 gallery_rest_Core {
  static function get($request) {
    if (empty($request->path)) {
      return rest::invalid_request();
    }

    $item = ORM::factory("item")
      ->where("relative_url_cache", $request->path)
      ->viewable()
      ->find();

    if (!$item->loaded) {
      return rest::not_found("Resource: {$request->path} missing.");
    }

    $response_data = array("path" => $item->relative_url(),
                           "title" => $item->title,
                           "thumb_url" => $item->thumb_url(),
                           "url" => $item->abs_url(),
                           "description" => $item->description,
                           "internet_address" => $item->slug);

    $children = self::_get_children($item, $request);
    if (!empty($children)) {
      $response_data["children"] = $children;
    }
    return rest::success(array($item->type => $response_data));
  }

  static function put($request) {
    if (empty($request->path)) {
      return rest::invalid_request();
    }

    $item = ORM::factory("item")
      ->where("relative_url_cache", $request->path)
      ->viewable()
      ->find();

    if (!$item->loaded) {
      return rest::not_found("Resource: {$request->path} missing.");
    }

    if (!access::can("edit", $item)) {
      return rest::not_found("Resource: {$request->path} permission denied.");
    }

    // Normalize the request
    $new_values = array();
    $fields = array("title", "description", "name", "slug");
    if ($item->is_album()) {
      $fields = array_merge($fields, array("sort_column", "sort_order"));
    }
    foreach ($fields as $field) {
      $new_values[$field] = !empty($request->$field) ? $request->$field : $item->$field;
    }
    if ($item->id == 1) {
      unset($new_values["name"]);
    }
    if ($item->id != 1 &&
        ($new_values["name"] != $item->name || $new_values["slug"] != $item->slug)) {
      // Make sure that there's not a conflict
      $errors = item::check_for_conflicts($item, $new_values["name"], $new_values["slug"]);
      if (!empty($errors["name_conflict"])) {
        return rest::fail(t("Renaming %path failed: new name exists",
                            array("path" => $request->path)));
      }
      if (!empty($errors["slug_conflict"])) {
        return rest::fail(t("Renaming %path failed: new internet address exists",
                            array("path" => $request->path)));
      }
    }

    item::update($item, $new_values);

    log::success("content", "Updated $item->type", "<a href=\"{$item->type}s/$item->id\">view</a>");

    return rest::success();
  }

  private static function _get_children($item, $request) {
    $children = array();
    $limit = empty($request->limit) ? null : $request->limit;
    $offset = empty($request->offset) ? null : $request->offset;
    $where = empty($request->filter) ? array() : array("type" => $request->filter);
    foreach ($item->viewable()->children($limit, $offset, $where) as $child) {
      $children[] = array("type" => $child->type,
                          "has_children" => $child->children_count() > 0,
                          "path" => $child->relative_url(),
                          "title" => $child->title);
    }

    return $children;
  }
}