Class: Webmachine::DescribeRoutes

Inherits:
Object
  • Object
show all
Defined in:
lib/webmachine/describe_routes.rb

Defined Under Namespace

Classes: Route

Class Method Summary collapse

Class Method Details

.call(webmachine_applications, search_term: nil) ⇒ Object



61
62
63
64
65
66
67
68
69
# File 'lib/webmachine/describe_routes.rb', line 61

def self.call(webmachine_applications, search_term: nil)
  path_mappings = webmachine_applications.flat_map { | webmachine_application | paths_to_resource_class_mappings(webmachine_application) }

  if search_term
    path_mappings = path_mappings.select{ |(route, _)| route[:path].include?(search_term) }
  end

  path_mappings.sort_by{ | mapping | mapping[:path] }
end

.info_from_resource_instance(webmachine_route) ⇒ Object



84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# File 'lib/webmachine/describe_routes.rb', line 84

def self.info_from_resource_instance(webmachine_route)
  with_no_logging do
    path_info = { application_context: OpenStruct.new, pacticipant_name: "foo", pacticipant_version_number: "1", resource_name: "foo" }
    path_info.default = "1"
    dummy_request = Webmachine::Adapters::Rack::RackRequest.new("GET", "/", Webmachine::Headers["host" => "example.org"], nil, {}, {}, { "REQUEST_METHOD" => "GET" })
    dummy_request.path_info = path_info
    dummy_resource = webmachine_route.resource.new(dummy_request, Webmachine::Response.new)
    if dummy_resource
      {
        allowed_methods: dummy_resource.allowed_methods,
      }
    else
      {}
    end
  end
rescue StandardError => e
  puts "Could not determine instance info for #{route.resource}. #{e.class} - #{e.message}"
  {}
end

.paths_to_resource_class_mappings(webmachine_application) ⇒ Object



71
72
73
74
75
76
77
78
79
80
81
82
# File 'lib/webmachine/describe_routes.rb', line 71

def self.paths_to_resource_class_mappings(webmachine_application)
  webmachine_application.routes.collect do | webmachine_route |
    resource_path_absolute = Pathname.new(source_location_for(webmachine_route.resource))
    Route.new({
      path: "/" + webmachine_route.path_spec.collect{ |part| part.is_a?(Symbol) ? ":#{part}" : part  }.join("/"),
      path_spec: webmachine_route.path_spec,
      resource_class: webmachine_route.resource,
      resource_name: webmachine_route.instance_variable_get(:@bindings)[:resource_name],
      resource_class_location: resource_path_absolute.relative_path_from(Pathname.pwd).to_s
    }.merge(info_from_resource_instance(webmachine_route)))
  end.reject{ | route | route.resource_class == Webmachine::Trace::TraceResource }
end

.source_location_for(clazz) ⇒ Object



104
105
106
107
# File 'lib/webmachine/describe_routes.rb', line 104

def self.source_location_for(clazz)
  first_instance_method_name = (clazz.instance_methods(false) + clazz.private_instance_methods(false)).first
  clazz.instance_method(first_instance_method_name).source_location.first
end

.with_no_loggingObject

If we don’t turn off the logging, we get metrics logging due to the instantiation of the Webmachine::RackRequest class



110
111
112
113
114
115
116
# File 'lib/webmachine/describe_routes.rb', line 110

def self.with_no_logging
  original_default_level = SemanticLogger.default_level
  SemanticLogger.default_level = :fatal
  yield
ensure
  SemanticLogger.default_level = original_default_level
end