Class: Merge::Ticketing::Ticket
- Inherits:
-
Object
- Object
- Merge::Ticketing::Ticket
- Defined in:
- lib/merge_ruby_client/ticketing/types/ticket.rb
Overview
# The Ticket Object
### Description
The `Ticket` object is used to represent a ticket, issue, task or case.
### Usage Example
TODO
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#access_level ⇒ Merge::Ticketing::TicketAccessLevelEnum
readonly
The description of who is able to access a given ticket, or where access is inherited from.
-
#account ⇒ Merge::Ticketing::TicketAccount
readonly
The account associated with the ticket.
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#assigned_teams ⇒ Array<Merge::Ticketing::TicketAssignedTeamsItem>
readonly
The ‘Teams` that are assigned to this ticket.
-
#assignees ⇒ Array<Merge::Ticketing::TicketAssigneesItem>
readonly
The individual ‘Users` who are assigned to this ticket.
- #attachments ⇒ Array<Merge::Ticketing::TicketAttachmentsItem> readonly
-
#collections ⇒ Array<Merge::Ticketing::TicketCollectionsItem>
readonly
The ‘Collections` that this `Ticket` is included in.
-
#completed_at ⇒ DateTime
readonly
When the ticket was completed.
-
#contact ⇒ Merge::Ticketing::TicketContact
readonly
The contact associated with the ticket.
-
#created_at ⇒ DateTime
readonly
The datetime that this object was created by Merge.
-
#creator ⇒ Merge::Ticketing::TicketCreator
readonly
The user who created this ticket.
-
#description ⇒ String
readonly
The ticket’s description.
-
#due_date ⇒ DateTime
readonly
The ticket’s due date.
- #field_mappings ⇒ Hash{String => Object} readonly
- #id ⇒ String readonly
-
#modified_at ⇒ DateTime
readonly
The datetime that this object was modified by Merge.
-
#name ⇒ String
readonly
The ticket’s name.
-
#parent_ticket ⇒ Merge::Ticketing::TicketParentTicket
readonly
The ticket’s parent ticket.
-
#priority ⇒ Merge::Ticketing::PriorityEnum
readonly
The priority or urgency of the Ticket.
-
#remote_created_at ⇒ DateTime
readonly
When the third party’s ticket was created.
- #remote_data ⇒ Array<Merge::Ticketing::RemoteData> readonly
- #remote_fields ⇒ Array<Merge::Ticketing::RemoteField> readonly
-
#remote_id ⇒ String
readonly
The third-party API ID of the matching object.
-
#remote_updated_at ⇒ DateTime
readonly
When the third party’s ticket was updated.
-
#remote_was_deleted ⇒ Boolean
readonly
Indicates whether or not this object has been deleted in the third party platform.
- #roles ⇒ Array<String> readonly
-
#status ⇒ Merge::Ticketing::TicketStatusEnum
readonly
The current status of the ticket.
- #tags ⇒ Array<String> readonly
-
#ticket_type ⇒ String
readonly
The sub category of the ticket within the 3rd party system.
-
#ticket_url ⇒ String
readonly
The 3rd party url of the Ticket.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ Merge::Ticketing::Ticket
Deserialize a JSON object to an instance of Ticket.
-
.validate_raw(obj:) ⇒ Void
Leveraged for Union-type generation, validate_raw attempts to parse the given hash and check each fields type against the current object’s property definitions.
Instance Method Summary collapse
- #initialize(id: OMIT, remote_id: OMIT, created_at: OMIT, modified_at: OMIT, name: OMIT, assignees: OMIT, assigned_teams: OMIT, creator: OMIT, due_date: OMIT, status: OMIT, description: OMIT, collections: OMIT, ticket_type: OMIT, account: OMIT, contact: OMIT, parent_ticket: OMIT, attachments: OMIT, access_level: OMIT, tags: OMIT, roles: OMIT, remote_created_at: OMIT, remote_updated_at: OMIT, completed_at: OMIT, remote_was_deleted: OMIT, ticket_url: OMIT, priority: OMIT, field_mappings: OMIT, remote_data: OMIT, remote_fields: OMIT, additional_properties: nil) ⇒ Merge::Ticketing::Ticket constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of Ticket to a JSON object.
Constructor Details
#initialize(id: OMIT, remote_id: OMIT, created_at: OMIT, modified_at: OMIT, name: OMIT, assignees: OMIT, assigned_teams: OMIT, creator: OMIT, due_date: OMIT, status: OMIT, description: OMIT, collections: OMIT, ticket_type: OMIT, account: OMIT, contact: OMIT, parent_ticket: OMIT, attachments: OMIT, access_level: OMIT, tags: OMIT, roles: OMIT, remote_created_at: OMIT, remote_updated_at: OMIT, completed_at: OMIT, remote_was_deleted: OMIT, ticket_url: OMIT, priority: OMIT, field_mappings: OMIT, remote_data: OMIT, remote_fields: OMIT, additional_properties: nil) ⇒ Merge::Ticketing::Ticket
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 173 def initialize(id: OMIT, remote_id: OMIT, created_at: OMIT, modified_at: OMIT, name: OMIT, assignees: OMIT, assigned_teams: OMIT, creator: OMIT, due_date: OMIT, status: OMIT, description: OMIT, collections: OMIT, ticket_type: OMIT, account: OMIT, contact: OMIT, parent_ticket: OMIT, attachments: OMIT, access_level: OMIT, tags: OMIT, roles: OMIT, remote_created_at: OMIT, remote_updated_at: OMIT, completed_at: OMIT, remote_was_deleted: OMIT, ticket_url: OMIT, priority: OMIT, field_mappings: OMIT, remote_data: OMIT, remote_fields: OMIT, additional_properties: nil) @id = id if id != OMIT @remote_id = remote_id if remote_id != OMIT @created_at = created_at if created_at != OMIT @modified_at = modified_at if modified_at != OMIT @name = name if name != OMIT @assignees = assignees if assignees != OMIT @assigned_teams = assigned_teams if assigned_teams != OMIT @creator = creator if creator != OMIT @due_date = due_date if due_date != OMIT @status = status if status != OMIT @description = description if description != OMIT @collections = collections if collections != OMIT @ticket_type = ticket_type if ticket_type != OMIT @account = account if account != OMIT @contact = contact if contact != OMIT @parent_ticket = parent_ticket if parent_ticket != OMIT @attachments = if != OMIT @access_level = access_level if access_level != OMIT @tags = if != OMIT @roles = roles if roles != OMIT @remote_created_at = remote_created_at if remote_created_at != OMIT @remote_updated_at = remote_updated_at if remote_updated_at != OMIT @completed_at = completed_at if completed_at != OMIT @remote_was_deleted = remote_was_deleted if remote_was_deleted != OMIT @ticket_url = ticket_url if ticket_url != OMIT @priority = priority if priority != OMIT @field_mappings = field_mappings if field_mappings != OMIT @remote_data = remote_data if remote_data != OMIT @remote_fields = remote_fields if remote_fields != OMIT @additional_properties = additional_properties @_field_set = { "id": id, "remote_id": remote_id, "created_at": created_at, "modified_at": modified_at, "name": name, "assignees": assignees, "assigned_teams": assigned_teams, "creator": creator, "due_date": due_date, "status": status, "description": description, "collections": collections, "ticket_type": ticket_type, "account": account, "contact": contact, "parent_ticket": parent_ticket, "attachments": , "access_level": access_level, "tags": , "roles": roles, "remote_created_at": remote_created_at, "remote_updated_at": remote_updated_at, "completed_at": completed_at, "remote_was_deleted": remote_was_deleted, "ticket_url": ticket_url, "priority": priority, "field_mappings": field_mappings, "remote_data": remote_data, "remote_fields": remote_fields }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#access_level ⇒ Merge::Ticketing::TicketAccessLevelEnum (readonly)
Returns The description of who is able to access a given ticket, or where access is inherited from.
-
‘COMPANY` - COMPANY
-
‘PUBLIC` - PUBLIC
-
‘PRIVATE` - PRIVATE
-
‘COLLECTION` - COLLECTION.
80 81 82 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 80 def access_level @access_level end |
#account ⇒ Merge::Ticketing::TicketAccount (readonly)
Returns The account associated with the ticket.
67 68 69 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 67 def account @account end |
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
111 112 113 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 111 def additional_properties @additional_properties end |
#assigned_teams ⇒ Array<Merge::Ticketing::TicketAssignedTeamsItem> (readonly)
Returns The ‘Teams` that are assigned to this ticket. This does not include `Teams` who just have view access to this ticket. To fetch all `Users` and `Teams` that can access this ticket, use the `GET /tickets/ticket_id/viewers` [endpoint](docs.merge.dev/ticketing/tickets/#tickets_viewers_list).
47 48 49 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 47 def assigned_teams @assigned_teams end |
#assignees ⇒ Array<Merge::Ticketing::TicketAssigneesItem> (readonly)
Returns The individual ‘Users` who are assigned to this ticket. This does not include `Users` who just have view access to this ticket. To fetch all `Users` and `Teams` that can access the ticket, use the `GET /tickets/ticket_id/viewers` [endpoint](docs.merge.dev/ticketing/tickets/#tickets_viewers_list).
42 43 44 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 42 def assignees @assignees end |
#attachments ⇒ Array<Merge::Ticketing::TicketAttachmentsItem> (readonly)
73 74 75 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 73 def @attachments end |
#collections ⇒ Array<Merge::Ticketing::TicketCollectionsItem> (readonly)
Returns The ‘Collections` that this `Ticket` is included in.
62 63 64 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 62 def collections @collections end |
#completed_at ⇒ DateTime (readonly)
Returns When the ticket was completed.
90 91 92 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 90 def completed_at @completed_at end |
#contact ⇒ Merge::Ticketing::TicketContact (readonly)
Returns The contact associated with the ticket.
69 70 71 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 69 def contact @contact end |
#created_at ⇒ DateTime (readonly)
Returns The datetime that this object was created by Merge.
33 34 35 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 33 def created_at @created_at end |
#creator ⇒ Merge::Ticketing::TicketCreator (readonly)
Returns The user who created this ticket.
49 50 51 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 49 def creator @creator end |
#description ⇒ String (readonly)
Returns The ticket’s description. HTML version of description is mapped if supported by the third-party platform.
60 61 62 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 60 def description @description end |
#due_date ⇒ DateTime (readonly)
Returns The ticket’s due date.
51 52 53 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 51 def due_date @due_date end |
#field_mappings ⇒ Hash{String => Object} (readonly)
105 106 107 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 105 def field_mappings @field_mappings end |
#id ⇒ String (readonly)
29 30 31 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 29 def id @id end |
#modified_at ⇒ DateTime (readonly)
Returns The datetime that this object was modified by Merge.
35 36 37 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 35 def modified_at @modified_at end |
#name ⇒ String (readonly)
Returns The ticket’s name.
37 38 39 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 37 def name @name end |
#parent_ticket ⇒ Merge::Ticketing::TicketParentTicket (readonly)
Returns The ticket’s parent ticket.
71 72 73 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 71 def parent_ticket @parent_ticket end |
#priority ⇒ Merge::Ticketing::PriorityEnum (readonly)
Returns The priority or urgency of the Ticket.
-
‘URGENT` - URGENT
-
‘HIGH` - HIGH
-
‘NORMAL` - NORMAL
-
‘LOW` - LOW.
103 104 105 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 103 def priority @priority end |
#remote_created_at ⇒ DateTime (readonly)
Returns When the third party’s ticket was created.
86 87 88 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 86 def remote_created_at @remote_created_at end |
#remote_data ⇒ Array<Merge::Ticketing::RemoteData> (readonly)
107 108 109 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 107 def remote_data @remote_data end |
#remote_fields ⇒ Array<Merge::Ticketing::RemoteField> (readonly)
109 110 111 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 109 def remote_fields @remote_fields end |
#remote_id ⇒ String (readonly)
Returns The third-party API ID of the matching object.
31 32 33 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 31 def remote_id @remote_id end |
#remote_updated_at ⇒ DateTime (readonly)
Returns When the third party’s ticket was updated.
88 89 90 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 88 def remote_updated_at @remote_updated_at end |
#remote_was_deleted ⇒ Boolean (readonly)
Returns Indicates whether or not this object has been deleted in the third party platform. Full coverage deletion detection is a premium add-on. Native deletion detection is offered for free with limited coverage. [Learn more](docs.merge.dev/integrations/hris/supported-features/).
95 96 97 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 95 def remote_was_deleted @remote_was_deleted end |
#roles ⇒ Array<String> (readonly)
84 85 86 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 84 def roles @roles end |
#status ⇒ Merge::Ticketing::TicketStatusEnum (readonly)
Returns The current status of the ticket.
-
‘OPEN` - OPEN
-
‘CLOSED` - CLOSED
-
‘IN_PROGRESS` - IN_PROGRESS
-
‘ON_HOLD` - ON_HOLD.
57 58 59 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 57 def status @status end |
#tags ⇒ Array<String> (readonly)
82 83 84 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 82 def @tags end |
#ticket_type ⇒ String (readonly)
Returns The sub category of the ticket within the 3rd party system. Examples include incident, task, subtask or to-do.
65 66 67 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 65 def ticket_type @ticket_type end |
#ticket_url ⇒ String (readonly)
Returns The 3rd party url of the Ticket.
97 98 99 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 97 def ticket_url @ticket_url end |
Class Method Details
.from_json(json_object:) ⇒ Merge::Ticketing::Ticket
Deserialize a JSON object to an instance of Ticket
244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 244 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) id = parsed_json["id"] remote_id = parsed_json["remote_id"] created_at = (DateTime.parse(parsed_json["created_at"]) unless parsed_json["created_at"].nil?) modified_at = (DateTime.parse(parsed_json["modified_at"]) unless parsed_json["modified_at"].nil?) name = parsed_json["name"] assignees = parsed_json["assignees"]&.map do |item| item = item.to_json Merge::Ticketing::TicketAssigneesItem.from_json(json_object: item) end assigned_teams = parsed_json["assigned_teams"]&.map do |item| item = item.to_json Merge::Ticketing::TicketAssignedTeamsItem.from_json(json_object: item) end if parsed_json["creator"].nil? creator = nil else creator = parsed_json["creator"].to_json creator = Merge::Ticketing::TicketCreator.from_json(json_object: creator) end due_date = (DateTime.parse(parsed_json["due_date"]) unless parsed_json["due_date"].nil?) status = parsed_json["status"] description = parsed_json["description"] collections = parsed_json["collections"]&.map do |item| item = item.to_json Merge::Ticketing::TicketCollectionsItem.from_json(json_object: item) end ticket_type = parsed_json["ticket_type"] if parsed_json["account"].nil? account = nil else account = parsed_json["account"].to_json account = Merge::Ticketing::TicketAccount.from_json(json_object: account) end if parsed_json["contact"].nil? contact = nil else contact = parsed_json["contact"].to_json contact = Merge::Ticketing::TicketContact.from_json(json_object: contact) end if parsed_json["parent_ticket"].nil? parent_ticket = nil else parent_ticket = parsed_json["parent_ticket"].to_json parent_ticket = Merge::Ticketing::TicketParentTicket.from_json(json_object: parent_ticket) end = parsed_json["attachments"]&.map do |item| item = item.to_json Merge::Ticketing::TicketAttachmentsItem.from_json(json_object: item) end access_level = parsed_json["access_level"] = parsed_json["tags"] roles = parsed_json["roles"] remote_created_at = unless parsed_json["remote_created_at"].nil? DateTime.parse(parsed_json["remote_created_at"]) end remote_updated_at = unless parsed_json["remote_updated_at"].nil? DateTime.parse(parsed_json["remote_updated_at"]) end completed_at = (DateTime.parse(parsed_json["completed_at"]) unless parsed_json["completed_at"].nil?) remote_was_deleted = parsed_json["remote_was_deleted"] ticket_url = parsed_json["ticket_url"] priority = parsed_json["priority"] field_mappings = parsed_json["field_mappings"] remote_data = parsed_json["remote_data"]&.map do |item| item = item.to_json Merge::Ticketing::RemoteData.from_json(json_object: item) end remote_fields = parsed_json["remote_fields"]&.map do |item| item = item.to_json Merge::Ticketing::RemoteField.from_json(json_object: item) end new( id: id, remote_id: remote_id, created_at: created_at, modified_at: modified_at, name: name, assignees: assignees, assigned_teams: assigned_teams, creator: creator, due_date: due_date, status: status, description: description, collections: collections, ticket_type: ticket_type, account: account, contact: contact, parent_ticket: parent_ticket, attachments: , access_level: access_level, tags: , roles: roles, remote_created_at: remote_created_at, remote_updated_at: remote_updated_at, completed_at: completed_at, remote_was_deleted: remote_was_deleted, ticket_url: ticket_url, priority: priority, field_mappings: field_mappings, remote_data: remote_data, remote_fields: remote_fields, additional_properties: struct ) end |
.validate_raw(obj:) ⇒ Void
Leveraged for Union-type generation, validate_raw attempts to parse the given
hash and check each fields type against the current object's property
definitions.
365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 365 def self.validate_raw(obj:) obj.id&.is_a?(String) != false || raise("Passed value for field obj.id is not the expected type, validation failed.") obj.remote_id&.is_a?(String) != false || raise("Passed value for field obj.remote_id is not the expected type, validation failed.") obj.created_at&.is_a?(DateTime) != false || raise("Passed value for field obj.created_at is not the expected type, validation failed.") obj.modified_at&.is_a?(DateTime) != false || raise("Passed value for field obj.modified_at is not the expected type, validation failed.") obj.name&.is_a?(String) != false || raise("Passed value for field obj.name is not the expected type, validation failed.") obj.assignees&.is_a?(Array) != false || raise("Passed value for field obj.assignees is not the expected type, validation failed.") obj.assigned_teams&.is_a?(Array) != false || raise("Passed value for field obj.assigned_teams is not the expected type, validation failed.") obj.creator.nil? || Merge::Ticketing::TicketCreator.validate_raw(obj: obj.creator) obj.due_date&.is_a?(DateTime) != false || raise("Passed value for field obj.due_date is not the expected type, validation failed.") obj.status&.is_a?(Merge::Ticketing::TicketStatusEnum) != false || raise("Passed value for field obj.status is not the expected type, validation failed.") obj.description&.is_a?(String) != false || raise("Passed value for field obj.description is not the expected type, validation failed.") obj.collections&.is_a?(Array) != false || raise("Passed value for field obj.collections is not the expected type, validation failed.") obj.ticket_type&.is_a?(String) != false || raise("Passed value for field obj.ticket_type is not the expected type, validation failed.") obj.account.nil? || Merge::Ticketing::TicketAccount.validate_raw(obj: obj.account) obj.contact.nil? || Merge::Ticketing::TicketContact.validate_raw(obj: obj.contact) obj.parent_ticket.nil? || Merge::Ticketing::TicketParentTicket.validate_raw(obj: obj.parent_ticket) obj.&.is_a?(Array) != false || raise("Passed value for field obj.attachments is not the expected type, validation failed.") obj.access_level&.is_a?(Merge::Ticketing::TicketAccessLevelEnum) != false || raise("Passed value for field obj.access_level is not the expected type, validation failed.") obj.&.is_a?(Array) != false || raise("Passed value for field obj.tags is not the expected type, validation failed.") obj.roles&.is_a?(Array) != false || raise("Passed value for field obj.roles is not the expected type, validation failed.") obj.remote_created_at&.is_a?(DateTime) != false || raise("Passed value for field obj.remote_created_at is not the expected type, validation failed.") obj.remote_updated_at&.is_a?(DateTime) != false || raise("Passed value for field obj.remote_updated_at is not the expected type, validation failed.") obj.completed_at&.is_a?(DateTime) != false || raise("Passed value for field obj.completed_at is not the expected type, validation failed.") obj.remote_was_deleted&.is_a?(Boolean) != false || raise("Passed value for field obj.remote_was_deleted is not the expected type, validation failed.") obj.ticket_url&.is_a?(String) != false || raise("Passed value for field obj.ticket_url is not the expected type, validation failed.") obj.priority&.is_a?(Merge::Ticketing::PriorityEnum) != false || raise("Passed value for field obj.priority is not the expected type, validation failed.") obj.field_mappings&.is_a?(Hash) != false || raise("Passed value for field obj.field_mappings is not the expected type, validation failed.") obj.remote_data&.is_a?(Array) != false || raise("Passed value for field obj.remote_data is not the expected type, validation failed.") obj.remote_fields&.is_a?(Array) != false || raise("Passed value for field obj.remote_fields is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of Ticket to a JSON object
355 356 357 |
# File 'lib/merge_ruby_client/ticketing/types/ticket.rb', line 355 def to_json(*_args) @_field_set&.to_json end |