@new_resource_attrs ||= params[model_class.to_s.underscore.singularize]
@new_resource_attrs ||= {}
@new_resource_attrs.reject! { |k,v| k.to_s == 'uuid' }
- @object ||= model_class.new @new_resource_attrs
- @object.save!
- show
+ @object ||= model_class.new @new_resource_attrs, params["options"]
+ if @object.save
+ respond_to do |f|
+ f.json { render json: @object.attributes.merge(href: url_for(@object)) }
+ f.html {
+ redirect_to @object
+ }
+ f.js { render }
+ end
+ else
+ self.render_error status: 422
+ end
end
def destroy
def preload_links_for_objects objects_and_uuids
uuids = objects_and_uuids.collect { |x| x.is_a?(String) ? x : x.uuid }
@all_links_for ||= {}
+
+ # if already preloaded for all of these uuids, return
if not uuids.select { |x| @all_links_for[x].nil? }.any?
- # already preloaded for all of these uuids
return
end
+
uuids.each do |x|
@all_links_for[x] = []
end
# helper method to get a certain number of objects of a specific type
# this can be used to replace any uses of: "dataclass.limit(n)"
- helper_method :get_objects_of_type
- def get_objects_of_type dataclass, size
+ helper_method :get_n_objects_of_class
+ def get_n_objects_of_class dataclass, size
# if the objects_map_for has a value for this dataclass, and the size used
- # to retrieve those objects is greater than equal to size, return it
+ # to retrieve those objects is greater than or equal to size, return it
size_key = "#{dataclass}_size"
if @objects_map_for && @objects_map_for[dataclass] && @objects_map_for[size_key] &&
(@objects_map_for[size_key] >= size)
- return @objects_map_for[dataclass]
+ return @objects_map_for[dataclass]
end
@objects_map_for = {}
return @objects_map_for[dataclass]
end
- # helper method to get collection for the given uuid
- helper_method :get_collection
- def get_collection uuid
- preload_collections([uuid])
- (@all_collections_for[uuid] && @all_collections_for[uuid].first) ?
- [@all_collections_for[uuid].first] : []
+ # helper method to get collections for the given uuid
+ helper_method :collections_for_object
+ def collections_for_object uuid
+ preload_collections_for_objects([uuid])
+ @all_collections_for[uuid]
end
# helper method to preload collections for the given uuids
- helper_method :preload_collections
- def preload_collections uuids
+ helper_method :preload_collections_for_objects
+ def preload_collections_for_objects uuids
@all_collections_for ||= {}
+
+ # if already preloaded for all of these uuids, return
if not uuids.select { |x| @all_collections_for[x].nil? }.any?
- # already preloaded for all of these uuids
return
end
end
end
- # helper method to get log collection for the given log
- helper_method :get_log_collection
- def get_log_collection log
+ # helper method to get log collections for the given log
+ helper_method :log_collections_for_object
+ def log_collections_for_object log
fixup = /([a-f0-9]{32}\+\d+)(\+?.*)/.match(log)
uuid = fixup[1]
- preload_log_collections([uuid])
- (@all_log_collections_for[uuid] && @all_log_collections_for[uuid].first) ?
- [@all_log_collections_for[uuid].first] : []
+ preload_log_collections_for_objects([uuid])
+ @all_log_collections_for[uuid]
end
# helper method to preload collections for the given uuids
- helper_method :preload_log_collections
- def preload_log_collections logs
+ helper_method :preload_log_collections_for_objects
+ def preload_log_collections_for_objects logs
uuids = []
logs.each do |log|
fixup = /([a-f0-9]{32}\+\d+)(\+?.*)/.match(log)
uuids << fixup[1]
end
+ # if already preloaded for all of these uuids, return
@all_log_collections_for ||= {}
if not uuids.select { |x| @all_log_collections_for[x].nil? }.any?
- # already preloaded for all of these uuids
return
end
end
# TODO: make sure we get every page of results from API server
- Collection.limit(100).where(uuid: uuids).each do |collection|
+ Collection.where(uuid: uuids).each do |collection|
@all_log_collections_for[collection.uuid] << collection
end
end
+ # helper method to get object of a given dataclass and uuid
+ helper_method :object_for_dataclass
+ def object_for_dataclass dataclass, uuid
+ preload_objects_for_dataclass(dataclass, [uuid])
+ @objects_for[uuid]
+ end
+
+ # helper method to preload objects for given dataclass and uuids
+ helper_method :preload_objects_for_dataclass
+ def preload_objects_for_dataclass dataclass, uuids
+ @objects_for ||= {}
+
+ # if already preloaded for all of these uuids, return
+ if not uuids.select { |x| @objects_for[x].nil? }.any?
+ return
+ end
+
+ dataclass.where(uuid: uuids).each do |obj|
+ @objects_for[obj.uuid] = obj
+ end
+ end
+
end