BUGFIX Quoting keys in JSONDataFormatter to ensure valid JSON (#5119)

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@99853 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Ingo Schommer 2010-02-25 00:00:24 +00:00
parent a4e14d3c56
commit 0b1fc5b91b

View File

@ -36,16 +36,16 @@ class JSONDataFormatter extends DataFormatter {
$className = $obj->class; $className = $obj->class;
$id = $obj->ID; $id = $obj->ID;
$json = "{\n className : \"$className\",\n"; $json = "{\n \"className\" : \"$className\",\n";
foreach($this->getFieldsForObj($obj) as $fieldName => $fieldType) { foreach($this->getFieldsForObj($obj) as $fieldName => $fieldType) {
// Field filtering // Field filtering
if($fields && !in_array($fieldName, $fields)) continue; if($fields && !in_array($fieldName, $fields)) continue;
$fieldValue = $obj->$fieldName; $fieldValue = $obj->$fieldName;
if(is_object($fieldValue) && is_subclass_of($fieldValue, 'Object') && $fieldValue->hasMethod('toJSON')) { if(is_object($fieldValue) && is_subclass_of($fieldValue, 'Object') && $fieldValue->hasMethod('toJSON')) {
$jsonParts[] = "$fieldName : " . $fieldValue->toJSON(); $jsonParts[] = "\"$fieldName\" : " . $fieldValue->toJSON();
} else { } else {
$jsonParts[] = "$fieldName : " . Convert::raw2json($fieldValue); $jsonParts[] = "\"$fieldName\" : " . Convert::raw2json($fieldValue);
} }
} }
@ -63,7 +63,7 @@ class JSONDataFormatter extends DataFormatter {
} else { } else {
$href = Director::absoluteURL(self::$api_base . "$className/$id/$relName"); $href = Director::absoluteURL(self::$api_base . "$className/$id/$relName");
} }
$jsonParts[] = "$relName : { className : \"$relClass\", href : \"$href.json\", id : \"{$obj->$fieldName}\" }"; $jsonParts[] = "$relName : { \"className\" : \"$relClass\", \"href\" : \"$href.json\", \"id\" : \"{$obj->$fieldName}\" }";
} }
foreach($obj->has_many() as $relName => $relClass) { foreach($obj->has_many() as $relName => $relClass) {
@ -78,7 +78,7 @@ class JSONDataFormatter extends DataFormatter {
foreach($items as $item) { foreach($items as $item) {
//$href = Director::absoluteURL(self::$api_base . "$className/$id/$relName/$item->ID"); //$href = Director::absoluteURL(self::$api_base . "$className/$id/$relName/$item->ID");
$href = Director::absoluteURL(self::$api_base . "$relClass/$item->ID"); $href = Director::absoluteURL(self::$api_base . "$relClass/$item->ID");
$jsonInnerParts[] = "{ className : \"$relClass\", href : \"$href.json\", id : \"{$obj->$fieldName}\" }"; $jsonInnerParts[] = "{ \"className\" : \"$relClass\", \"href\" : \"$href.json\", \"id\" : \"{$obj->$fieldName}\" }";
} }
$jsonParts[] = "$relName : [\n " . implode(",\n ", $jsonInnerParts) . " \n ]"; $jsonParts[] = "$relName : [\n " . implode(",\n ", $jsonInnerParts) . " \n ]";
} }
@ -95,7 +95,7 @@ class JSONDataFormatter extends DataFormatter {
foreach($items as $item) { foreach($items as $item) {
//$href = Director::absoluteURL(self::$api_base . "$className/$id/$relName/$item->ID"); //$href = Director::absoluteURL(self::$api_base . "$className/$id/$relName/$item->ID");
$href = Director::absoluteURL(self::$api_base . "$relClass/$item->ID"); $href = Director::absoluteURL(self::$api_base . "$relClass/$item->ID");
$jsonInnerParts[] = " { className : \"$relClass\", href : \"$href.json\", id : \"{$obj->$fieldName}\" }"; $jsonInnerParts[] = " { \"className\" : \"$relClass\", \"href\" : \"$href.json\", \"id\" : \"{$obj->$fieldName}\" }";
} }
$jsonParts[] = "$relName : [\n " . implode(",\n ", $jsonInnerParts) . "\n ]"; $jsonParts[] = "$relName : [\n " . implode(",\n ", $jsonInnerParts) . "\n ]";
} }
@ -115,10 +115,10 @@ class JSONDataFormatter extends DataFormatter {
if($item->canView()) $jsonParts[] = $this->convertDataObject($item, $fields); if($item->canView()) $jsonParts[] = $this->convertDataObject($item, $fields);
} }
$json = "{\n"; $json = "{\n";
$json .= 'totalSize: '; $json .= '\"totalSize\": ';
$json .= (is_numeric($this->totalSize)) ? $this->totalSize : 'null'; $json .= (is_numeric($this->totalSize)) ? $this->totalSize : 'null';
$json .= ",\n"; $json .= ",\n";
$json .= "items: [\n" . implode(",\n", $jsonParts) . "\n]\n"; $json .= "\"items\": [\n" . implode(",\n", $jsonParts) . "\n]\n";
$json .= "}\n"; $json .= "}\n";
return $json; return $json;