summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorTim Almdal <tnalmdal@shaw.ca>2009-12-22 12:32:27 -0800
committerTim Almdal <tnalmdal@shaw.ca>2009-12-22 12:32:27 -0800
commitcbe5a89a9fa6ac19f89eacf3821c3f46bc42bf3f (patch)
tree582aed3c7bac20c64504b70725590db3ab9971c4 /modules
parentfd7990735cc73b5b1494190b9c187297e588a9f6 (diff)
Update the api so it allows images to be uploaded.
Diffstat (limited to 'modules')
-rw-r--r--modules/gallery/helpers/gallery_rest.php52
-rw-r--r--modules/rest/controllers/rest.php3
2 files changed, 33 insertions, 22 deletions
diff --git a/modules/gallery/helpers/gallery_rest.php b/modules/gallery/helpers/gallery_rest.php
index e31c4252..a3b1997d 100644
--- a/modules/gallery/helpers/gallery_rest.php
+++ b/modules/gallery/helpers/gallery_rest.php
@@ -72,7 +72,7 @@ class gallery_rest_Core {
}
// Validate the request data
- $new_values = gallery_rest::_validate($item, $request);
+ $new_values = gallery_rest::_validate($request, $item);
$errors = $new_values->errors();
if (empty($errors)) {
item::update($item, $new_values->as_array());
@@ -106,9 +106,14 @@ class gallery_rest_Core {
return rest::not_found("Resource: {$request->path} permission denied.");
}
- // @TODO validate input values (assume nothing about the quality of input)
+ // Validate the request data
+ $new_values = gallery_rest::_validate($request);
+ $errors = $new_values->errors();
+ if (!empty($errors)) {
+ return rest::validation_error($errors);
+ }
- if (empty($_FILES["image"])) {
+ if (empty($new_values["image"])) {
$new_item = album::create(
$parent,
$name,
@@ -118,25 +123,16 @@ class gallery_rest_Core {
empty($request->slug) ? $name : $request->slug);
$log_message = t("Added an album");
} else {
- $file_validation = new Validation($_FILES);
- $file_validation->add_rules(
- "image", "upload::valid", "upload::required", "upload::type[gif,jpg,jpeg,png,flv,mp4]");
- if (!$file_validation->validate()) {
- $errors = $file_validation->errors();
- return rest::fail(
- $errors["image"] == "type" ? "Upload failed: Unsupported file type" :
- "Upload failed: Uploaded file missing");
- }
$temp_filename = upload::save("image");
- $name = substr(basename($temp_filename), 10); // Skip unique identifier Kohana adds
- $title = item::convert_filename_to_title($name);
$path_info = @pathinfo($temp_filename);
if (array_key_exists("extension", $path_info) &&
in_array(strtolower($path_info["extension"]), array("flv", "mp4"))) {
- $new_item = movie::create($parent, $temp_filename, $name, $title);
+ $new_item =
+ movie::create($parent, $temp_filename, $new_values["name"], $new_values["title"]);
$log_message = t("Added a movie");
} else {
- $new_item = photo::create($parent, $temp_filename, $name, $title);
+ $new_item =
+ photo::create($parent, $temp_filename, $new_values["name"], $new_values["title"]);
$log_message = t("Added a photo");
}
}
@@ -200,15 +196,23 @@ class gallery_rest_Core {
return $children;
}
- private static function _validate($item, $request) {
+ private static function _validate($request, $item=null) {
$new_values = array();
- $fields = array("title", "description", "name", "slug");
+ $fields = array("title", "description", "name", "slug", "image");
+ if (empty($item)) {
+ $item = ORM::factory("item");
+ $item->id = 0;
+ }
if ($item->id == 1) {
unset($request["name"]);
unset($request["slug"]);
}
foreach ($fields as $field) {
- $new_values[$field] = isset($request->$field) ? $request->$field : $item->$field;
+ if (isset($request->$field)) {
+ $new_values[$field] = $request->$field;
+ } else if (isset($item->$field)) {
+ $new_values[$field] = $item->$field;
+ }
}
$new_values = new Validation($new_values);
@@ -217,13 +221,17 @@ class gallery_rest_Core {
$new_values->add_rules($field, $rule);
}
}
+ if (isset($new_values["image"])) {
+ $new_values->add_rules(
+ "image", "upload::valid", "upload::required", "upload::type[gif,jpg,jpeg,png,flv,mp4]");
+ }
- if (($valid = $new_values->validate()) && $item->id != 1) {
+ if ($new_values->validate() && $item->id != 1) {
$errors = item::check_for_conflicts($item, $new_values["name"], $new_values["slug"]);
- if ($valid = empty($errors)) {
+ if (!empty($errors)) {
!empty($errors["name_conflict"]) OR $new_values->add_error("name", "Duplicate Name");
!empty($errors["slug_conflict"]) OR
- $new_values->add_error("name", "Duplicate Internet Address");
+ $new_values->add_error("slug", "Duplicate Internet Address");
}
}
diff --git a/modules/rest/controllers/rest.php b/modules/rest/controllers/rest.php
index 7a5ab46a..4d476a0d 100644
--- a/modules/rest/controllers/rest.php
+++ b/modules/rest/controllers/rest.php
@@ -76,6 +76,9 @@ class Rest_Controller extends Controller {
foreach (array_keys($this->input->post()) as $key) {
$request->$key = $this->input->post($key);
}
+ foreach (array_keys($_FILES) as $key) {
+ $request->$key = $_FILES[$key];
+ }
}
$request->method = strtolower($this->input->server("HTTP_X_GALLERY_REQUEST_METHOD", $method));