1 // Copyright 2004-2008 Castle Project - http://www.castleproject.org/
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
7 // http://www.apache.org/licenses/LICENSE-2.0
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
15 namespace Castle
.MonoRail
.Framework
.Helpers
20 /// Provides utilities methods to work with JSON.
22 public class JSONHelper
: AbstractHelper
26 /// Initializes a new instance of the <see cref="JSONHelper"/> class.
28 public JSONHelper() { }
30 /// Initializes a new instance of the <see cref="JSONHelper"/> class.
31 /// setting the Controller, Context and ControllerContext.
33 /// <param name="engineContext">The engine context.</param>
34 public JSONHelper(IEngineContext engineContext
) : base(engineContext
) { }
38 /// Converts a instance of the model to its JSON representation.
40 /// <param name="model">The model.</param>
41 /// <returns>The JSON representation of the model.</returns>
43 /// Suppose you have a car object instance, like this one:
45 /// Car car = new Car();
48 /// car.Model = "Cheap";
51 /// And to transform it to JSON, you must invoke the method passing the instance.
53 /// $helper.ToJSON(car)
55 /// Which will generate the JSON string:
57 /// {Wheels=4,Year=2007,Model='Cheap'}
60 public string ToJSON(object model
)
62 IJSONSerializer serializer
= Context
.Services
.JSONSerializer
;
64 if (serializer
== null)
66 throw new MonoRailException("Attempt to serialize object failed because the serializer is not available");
69 return serializer
.Serialize(model
);