diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-07-01 16:16:38 +0200 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-07-04 10:25:07 +0200 |
commit | 479c7533db672c2e4b96e8fdcc41142570c39069 (patch) | |
tree | 4a47e27a4dd796e7b00649b0df2ed24ece5aea31 /server | |
parent | 1cc993f6dae7a22df577faa7101d06dc6c594974 (diff) | |
download | sonarqube-479c7533db672c2e4b96e8fdcc41142570c39069.tar.gz sonarqube-479c7533db672c2e4b96e8fdcc41142570c39069.zip |
Revert "SONAR-7858 Stop support of XML response in web services"
This reverts commit 8d277d413f1739763f32d893c7eb9740bcac6c57.
Diffstat (limited to 'server')
20 files changed, 444 insertions, 30 deletions
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/api_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/api_controller.rb index fea19b175de..dca3fc1bf57 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/api_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/api_controller.rb @@ -119,7 +119,11 @@ class Api::ApiController < ApplicationController end def render_response(status, message) - render :json => error_to_json(status, message), :status => status + respond_to do |format| + format.json { render :json => error_to_json(status, message), :status => status } + format.xml { render :xml => error_to_xml(status, message), :status => status } + format.text { render :text => message, :status => status } + end end def error_to_json(status, message=nil) diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/components_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/components_controller.rb index 24e4a86acd7..cdf63cd52a8 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/components_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/components_controller.rb @@ -77,7 +77,11 @@ class Api::ComponentsController < Api::ApiController end json['results']=json_results - render :json => jsonp(json) + respond_to do |format| + format.json { render :json => jsonp(json) } + format.xml { render :xml => xml_not_supported } + format.text { render :text => text_not_supported } + end end private diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/events_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/events_controller.rb index dec487de655..4269dee6bb5 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/events_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/events_controller.rb @@ -67,7 +67,11 @@ class Api::EventsController < Api::ApiController events=Event.find(:all, :conditions => [conditions.join(' AND '), values], :order => 'event_date DESC') - render :json => jsonp(events_to_json(events)) + respond_to do |format| + format.json { render :json => jsonp(events_to_json(events)) } + format.xml { render :xml => events_to_xml(events) } + format.text { render :text => text_not_supported } + end rescue ApiException => e render_error(e.msg, e.code) @@ -85,7 +89,11 @@ class Api::EventsController < Api::ApiController event=Event.find(params[:id]) load_resource_by_uuid(:user, event.component_uuid) - render :json => jsonp(events_to_json([event])) + respond_to do |format| + format.json { render :json => jsonp(events_to_json([event])) } + format.xml { render :xml => events_to_xml([event]) } + format.text { render :text => text_not_supported } + end rescue ActiveRecord::RecordNotFound => e render_error(e.message, 404) @@ -156,7 +164,12 @@ class Api::EventsController < Api::ApiController event_to_return = event if snapshot.component_uuid = @resource.uuid end - render :json => jsonp(events_to_json([event_to_return])) + + respond_to do |format| + format.json { render :json => jsonp(events_to_json([event_to_return])) } + format.xml { render :xml => events_to_xml([event_to_return]) } + format.text { render :text => text_not_supported } + end rescue ApiException => e render_error(e.msg, e.code) @@ -260,4 +273,23 @@ class Api::EventsController < Api::ApiController hash end + def events_to_xml(events, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.events do + events.each do |event| + event_to_xml(event, xml) + end + end + end + + def event_to_xml(event, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.event do + xml.id(event.id.to_s) + xml.name(event.name) if event.name + xml.resourceKey(event.resource.key) if event.resource + xml.category(event.category) + xml.date(Api::Utils.format_datetime(event.event_date)) if event.event_date + xml.description(event.description) if event.description + end + end + end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/favourites_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/favourites_controller.rb index 91fb49f92e8..b92914e4723 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/favourites_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/favourites_controller.rb @@ -29,7 +29,11 @@ class Api::FavouritesController < Api::ApiController # curl http://localhost:9000/api/favourites -v -u admin:admin # def index - render :json => jsonp(favourites_to_json(current_user.favourites)) + respond_to do |format| + format.json { render :json => jsonp(favourites_to_json(current_user.favourites)) } + format.xml { render :xml => favourites_to_xml(current_user.favourites) } + format.text { render :text => text_not_supported } + end end # @@ -39,7 +43,11 @@ class Api::FavouritesController < Api::ApiController def create favourite=current_user.add_favourite(params[:key]) if favourite - render :json => jsonp(favourites_to_json([favourite])) + respond_to do |format| + format.json { render :json => jsonp(favourites_to_json([favourite])) } + format.xml { render :xml => favourites_to_xml([favourite]) } + format.text { render :text => text_not_supported } + end else render_error('Favourite not found', 404) end @@ -75,4 +83,33 @@ class Api::FavouritesController < Api::ApiController hash end + def favourites_to_xml(favourites, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.favourites do + favourites.each do |f| + xml.favourite do + xml.id(f.id) + xml.key(f.key) + xml.name(f.name) + xml.lname(f.long_name) if f.long_name + xml.branch(f.branch) if f.branch + xml.scope(f.scope) + xml.qualifier(f.qualifier) + xml.lang(f.language) if f.language + end + end + end + end + + def favourite_to_xml(favourite, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.favourite do + xml.id(f.id) + xml.key(f.key) + xml.name(f.name) + xml.lname(f.long_name) if f.long_name + xml.branch(f.branch) if f.branch + xml.scope(f.scope) + xml.qualifier(f.qualifier) + xml.lang(f.language) if f.language + end + end end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/issues_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/issues_controller.rb index 69b67f1dd39..62d75c2c884 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/issues_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/issues_controller.rb @@ -37,7 +37,10 @@ class Api::IssuesController < Api::ApiController hash = {} hash[:changelog] = Issue.changelog_to_hash(changelog) - render :json => jsonp(hash) + respond_to do |format| + format.json { render :json => jsonp(hash) } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'sonar') } + end end # @@ -78,7 +81,11 @@ class Api::IssuesController < Api::ApiController hash = result_to_hash(result) hash[:comment] = Issue.comment_to_hash(result.get) if result.get - render :json => jsonp(hash), :status => result.httpStatus + respond_to do |format| + # if the request header "Accept" is "*/*", then the default format is the first one (json) + format.json { render :json => jsonp(hash), :status => result.httpStatus } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'sonar', :status => http_status) } + end end # @@ -117,7 +124,11 @@ class Api::IssuesController < Api::ApiController hash = result_to_hash(result) hash[:comment] = Issue.comment_to_hash(result.get) if result.get - render :json => jsonp(hash), :status => result.httpStatus + respond_to do |format| + # if the request header "Accept" is "*/*", then the default format is the first one (json) + format.json { render :json => jsonp(hash), :status => result.httpStatus } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'sonar', :status => result.httpStatus) } + end end # @@ -174,7 +185,11 @@ class Api::IssuesController < Api::ApiController :issues => result.issuesNotChanged().map { |issue| issue.key() } } - render :json => jsonp(hash), :status => 200 + respond_to do |format| + # if the request header "Accept" is "*/*", then the default format is the first one (json) + format.json { render :json => jsonp(hash), :status => 200 } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'sonar', :status => 200) } + end end protected diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/profiles_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/profiles_controller.rb index e2176ae3243..892ec9e3eb4 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/profiles_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/profiles_controller.rb @@ -75,7 +75,11 @@ class Api::ProfilesController < Api::ApiController :language => profile.language, :default => default_profile_by_language[profile.language].name == profile.name } } - render :json => jsonp(json) + respond_to do |format| + format.json { render :json => jsonp(json) } + format.xml { render :xml => xml_not_supported } + format.text { render :text => text_not_supported } + end end # GET /api/profiles?language=<language>[&name=<name>] @@ -93,7 +97,11 @@ class Api::ProfilesController < Api::ApiController @active_rules=filter_rules() - render :json => jsonp(to_json) + respond_to do |format| + format.json { render :json => jsonp(to_json) } + format.xml { render :xml => to_xml } + format.text { render :text => text_not_supported } + end end private @@ -156,4 +164,31 @@ class Api::ProfilesController < Api::ApiController [result] end + def to_xml + xml = Builder::XmlMarkup.new(:indent => 0) + xml.instruct! + + xml.profile do + xml.name(@profile.name) + xml.language(@profile.language) + xml.parent(@profile.parent_kee) if @profile.parent_kee.present? + xml.default(@profile.default_profile?) + + @active_rules.each do |active_rule| + xml.rule do + xml.key(active_rule.rule.plugin_rule_key) + xml.repo(active_rule.rule.plugin_name) + xml.severity(active_rule.priority_text) + xml.inheritance(active_rule.inheritance) if active_rule.inheritance + active_rule.active_rule_parameters.each do |param| + xml.param do + xml.key(param.name) + xml.value(param.value) + end + end + end + end + end + end + end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/projects_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/projects_controller.rb index 4383a4c4115..bace6cd3b69 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/projects_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/projects_controller.rb @@ -39,7 +39,11 @@ class Api::ProjectsController < Api::ApiController @show_description=(params[:desc]=='true') @projects=load_projects @snapshots_by_puuid=load_snapshots_by_project - render :json => jsonp(to_json) + respond_to do |format| + format.json{ render :json => jsonp(to_json) } + format.xml { render :xml => to_xml } + format.text { render :text => text_not_supported } + end rescue Exception => e logger.error("Fails to execute #{request.url} : #{e.message}") @@ -62,7 +66,10 @@ class Api::ProjectsController < Api::ApiController id = Internal.component_api.createComponent(params[:key], params[:branch], params[:name], nil) result = Project.find(id.to_i) - render :json => jsonp(to_json_hash(result)) + respond_to do |format| + format.json { render :json => jsonp(to_json_hash(result)) } + format.xml { render :xml => to_xml_hash(result) } + end end private @@ -166,4 +173,29 @@ class Api::ProjectsController < Api::ApiController }.reject!{|k,v| v.nil?} end + def to_xml + xml = Builder::XmlMarkup.new(:indent => 0) + xml.projects do + @projects.each do |project| + to_xml_hash(project, xml) + end + end + end + + def to_xml_hash(project, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.project(:id => project.id.to_s, :key => project.key) do + xml.name(project.name(true)) + xml.scope(project.scope) + xml.qualifier(project.qualifier) + xml.desc(project.description) if @show_description && project.description + + if @snapshots_by_puuid && @snapshots_by_puuid[project.uuid] + @snapshots_by_puuid[project.id].sort{|s1,s2| s2.version <=> s1.version}.each do |snapshot| + attributes={:sid => snapshot.id.to_s, :last => snapshot.last?} + attributes[:date]=Api::Utils.format_datetime(snapshot.created_at) if snapshot.created_at + xml.version(snapshot.version, attributes) + end + end + end + end end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/properties_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/properties_controller.rb index f1c682f41ad..0c69c45098a 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/properties_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/properties_controller.rb @@ -58,7 +58,10 @@ class Api::PropertiesController < Api::ApiController # apply security properties = properties.select{|prop| allowed?(prop.key)} - render :json => jsonp(to_json(properties)) + respond_to do |format| + format.json { render :json => jsonp(to_json(properties)) } + format.xml { render :xml => to_xml(properties) } + end end # GET /api/properties/<key>[?resource=<resource>] @@ -79,10 +82,17 @@ class Api::PropertiesController < Api::ApiController unless prop # for backward-compatibility with versions <= 2.14 : keep status 200 message = "Property not found: #{key}" - render :json => error_to_json(404, message), :status => 200 + return respond_to do |format| + format.json { render :json => error_to_json(404, message), :status => 200 } + format.xml { render :xml => error_to_xml(404, message), :status => 200 } + format.text { render :text => message, :status => 200 } + end end access_denied unless allowed?(key) - render :json => jsonp(to_json([prop])) + respond_to do |format| + format.json { render :json => jsonp(to_json([prop])) } + format.xml { render :xml => to_xml([prop]) } + end end # curl -u admin:admin -v -X POST http://localhost:9000/api/properties/foo?value=bar[&resource=<resource>] @@ -135,6 +145,16 @@ class Api::PropertiesController < Api::ApiController properties.collect { |property| property.to_hash_json } end + def to_xml(properties) + xml = Builder::XmlMarkup.new(:indent => 0) + xml.instruct! + xml.properties do + properties.each do |property| + property.to_xml(xml) + end + end + end + def allowed?(property_key) !property_key.end_with?('.secured') || is_admin? || (property_key.include?(".license") && logged_in?) end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/resources_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/resources_controller.rb index f9f6b1ea7b1..3462125a2bc 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/resources_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/resources_controller.rb @@ -92,7 +92,11 @@ class Api::ResourcesController < Api::ApiController json = {:total => total, :page => page, :page_size => page_size, :data => resources.map { |r| {:id => r.id, :key => r.key, :nm => r.name(true), :q => r.qualifier} }} end - render :json => jsonp(json) + respond_to do |format| + format.json { render :json => jsonp(json) } + format.xml { render :xml => xml_not_supported } + format.text { render :text => text_not_supported } + end end def index @@ -228,7 +232,11 @@ class Api::ResourcesController < Api::ApiController # ---------- FORMAT RESPONSE objects={:sorted_components => sorted_components, :components_by_uuid => components_by_uuid, :measures_by_component_uuid => measures_by_component_uuid, :params => params} - render :json => jsonp(to_json(objects)) + respond_to do |format| + format.json { render :json => jsonp(to_json(objects)) } + format.xml { render :xml => to_xml(objects) } + format.text { render :text => text_not_supported } + end rescue ApiException => e render_error(e.msg, e.code) end @@ -264,6 +272,23 @@ class Api::ResourcesController < Api::ApiController result end + def to_xml(objects) + components = objects[:sorted_components] + components_by_uuid = objects[:components_by_uuid] + measures_by_component_uuid = objects[:measures_by_component_uuid] + params = objects[:params] + + xml = Builder::XmlMarkup.new(:indent => 0) + xml.instruct! + + xml.resources do + components.each do |component| + measures = measures_by_component_uuid[component.uuid] + resource_to_xml(xml, component, measures, params) + end + end + end + def component_to_json(component, measures, options={}) verbose=(options[:verbose]=='true') include_alerts=(options[:includealerts]=='true') @@ -340,4 +365,77 @@ class Api::ResourcesController < Api::ApiController json end + def resource_to_xml(xml, component, measures, options={}) + verbose=(options[:verbose]=='true') + include_alerts=(options[:includealerts]=='true') + include_trends=(options[:includetrends]=='true') + include_descriptions=(options[:includedescriptions]=='true') + + xml.resource do + xml.id(component.id) + xml.key(component.key) + xml.name(component.name) + xml.lname(component.long_name) if component.long_name + xml.branch(component.branch) if component.branch + xml.scope(component.scope) + xml.qualifier(component.qualifier) + xml.lang(component.language) if component.language + xml.version(snapshot.version) if snapshot.version + xml.date(Api::Utils.format_datetime(snapshot.created_at)) + xml.creationDate(Api::Utils.format_datetime(resource.created_at)) + xml.description(resource.description) if include_descriptions && resource.description + + if include_trends && component.last_snapshot + xml.period1(component.last_snapshot.period1_mode) if component.last_snapshot.period1_mode + xml.period1_param(component.last_snapshot.period1_param) if component.last_snapshot.period1_param + xml.period1_date(Api::Utils.format_datetime(component.last_snapshot.period1_date)) if component.last_snapshot.period1_date + + xml.period2(component.last_snapshot.period2_mode) if component.last_snapshot.period2_mode + xml.period2_param(component.last_snapshot.period2_param) if component.last_snapshot.period2_param + xml.period2_date(Api::Utils.format_datetime(component.last_snapshot.period2_date)) if component.last_snapshot.period2_date + + xml.period3(component.last_snapshot.period3_mode) if component.last_snapshot.period3_mode + xml.period3_param(component.last_snapshot.period3_param) if component.last_snapshot.period3_param + xml.period3_date(Api::Utils.format_datetime(component.last_snapshot.period3_date)) if component.last_snapshot.period3_date + + xml.period4(component.last_snapshot.period4_mode) if component.last_snapshot.period4_mode + xml.period4_param(component.last_snapshot.period4_param) if component.last_snapshot.period4_param + xml.period4_date(Api::Utils.format_datetime(component.last_snapshot.period4_date)) if component.last_snapshot.period4_date + + xml.period5(component.last_snapshot.period5_mode) if component.last_snapshot.period5_mode + xml.period5_param(component.last_snapshot.period5_param) if component.last_snapshot.period5_param + xml.period5_date(Api::Utils.format_datetime(component.last_snapshot.period5_date)) if component.last_snapshot.period5_date + end + + if measures + measures.select { |measure| !measure.metric.key.start_with?('new_') || include_trends }.each do |measure| + xml.msr do + xml.key(measure.metric.name) + xml.name(measure.metric.short_name) if verbose + xml.val(measure.value.to_f) if measure.value + xml.frmt_val(measure.formatted_value) if measure.value + xml.data(measure.data) if measure.data + xml.description(measure.description) if include_descriptions && measure.description + xml.url(measure.url) if include_descriptions && measure.url + if include_alerts + xml.alert(measure.alert_status) if measure.alert_status + xml.alert_text(measure.alert_text) if measure.alert_text + end + if include_trends + xml.var1(measure.variation_value_1.to_f) if measure.variation_value_1 + xml.fvar1(measure.format_numeric_value(measure.variation_value_1.to_f)) if measure.variation_value_1 + xml.var2(measure.variation_value_2.to_f) if measure.variation_value_2 + xml.fvar2(measure.format_numeric_value(measure.variation_value_2.to_f)) if measure.variation_value_2 + xml.var3(measure.variation_value_3.to_f) if measure.variation_value_3 + xml.fvar3(measure.format_numeric_value(measure.variation_value_3.to_f)) if measure.variation_value_3 + xml.var4(measure.variation_value_4.to_f) if measure.variation_value_4 + xml.fvar4(measure.format_numeric_value(measure.variation_value_4.to_f)) if measure.variation_value_4 + xml.var5(measure.variation_value_5.to_f) if measure.variation_value_5 + xml.fvar5(measure.format_numeric_value(measure.variation_value_5.to_f)) if measure.variation_value_5 + end + end + end + end + end + end end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/rest_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/rest_controller.rb index 525dd58f8e6..8bec1e4a2d0 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/rest_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/rest_controller.rb @@ -65,7 +65,11 @@ class Api::RestController < ApplicationController end def rest_render(objects) - render :json => rest_to_jsonp(objects) + respond_to do |format| + format.json{ render :json => rest_to_jsonp(objects) } + format.xml { render :xml => rest_to_xml(objects) } + format.text { render :text => rest_to_text(objects) } + end end def rest_to_jsonp(objects) diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/server_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/server_controller.rb index da39edf0766..c5c45639eb6 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/server_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/server_controller.rb @@ -34,7 +34,11 @@ class Api::ServerController < Api::ApiController def index hash={:id => Java::OrgSonarServerPlatform::Platform.getServer().getId(), :version => Java::OrgSonarServerPlatform::Platform.getServer().getVersion()} complete_with_status(hash) - render :json => jsonp(hash) + respond_to do |format| + format.json{ render :json => jsonp(hash) } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'server') } + format.text { render :text => text_not_supported} + end end def setup @@ -60,7 +64,11 @@ class Api::ServerController < Api::ApiController hash[:message]=manager.message if manager.message hash[:startedAt]=manager.migration_start_time if manager.migration_start_time - render :json => jsonp(hash) + respond_to do |format| + format.json{ render :json => jsonp(hash) } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'setup') } + format.text { render :text => hash[:status] } + end rescue => e hash={ # deprecated fields @@ -71,7 +79,11 @@ class Api::ServerController < Api::ApiController :message => e.message, :state => manager.status } - render :json => jsonp(hash) + respond_to do |format| + format.json{ render :json => jsonp(hash) } + format.xml { render :xml => hash.to_xml(:skip_types => true, :root => 'setup') } + format.text { render :text => hash[:status] } + end end end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/tests_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/tests_controller.rb index 522ba2d1f5b..b5ade1556e6 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/tests_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/tests_controller.rb @@ -70,7 +70,11 @@ class Api::TestsController < Api::ApiController end json.delete_if { |k, v| v.nil? } - render :json => jsonp(json) + respond_to do |format| + format.json { render :json => jsonp(json) } + format.xml { render :xml => xml_not_supported } + format.text { render :text => text_not_supported } + end end end @@ -117,6 +121,10 @@ class Api::TestsController < Api::ApiController end json.delete_if { |k, v| v.nil? } - render :json => jsonp(json) + respond_to do |format| + format.json { render :json => jsonp(json) } + format.xml { render :xml => xml_not_supported } + format.text { render :text => text_not_supported } + end end end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/updatecenter_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/updatecenter_controller.rb index 51f3b415297..c6e83dfe35b 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/updatecenter_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/updatecenter_controller.rb @@ -27,7 +27,11 @@ class Api::UpdatecenterController < Api::ApiController # curl http://localhost:9000/api/updatecenter/installed_plugins -v # def installed_plugins - render :json => jsonp(plugins_to_json(user_plugins())) + respond_to do |format| + format.json { render :json => jsonp(plugins_to_json(user_plugins())) } + format.xml { render :xml => plugins_to_xml(user_plugins()) } + format.text { render :text => text_not_supported } + end end private @@ -48,6 +52,18 @@ class Api::UpdatecenterController < Api::ApiController hash end + def plugins_to_xml(plugins, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.plugins do + plugins.each do |plugin| + xml.plugin do + xml.key(plugin.getKey()) + xml.name(plugin.getName()) + xml.version(plugin.getVersion().getName()) + end + end + end + end + def user_plugins java_facade.getPluginInfos().to_a.sort end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/user_properties_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/user_properties_controller.rb index fae02b8f73a..d25c2d23010 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/user_properties_controller.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/api/user_properties_controller.rb @@ -31,7 +31,11 @@ class Api::UserPropertiesController < Api::ApiController # def index properties = current_user.properties - render :json => jsonp(properties_to_json(properties)) + respond_to do |format| + format.json { render :json => jsonp(properties_to_json(properties)) } + format.xml { render :xml => properties_to_xml(properties) } + format.text { render :text => text_not_supported } + end end # @@ -41,7 +45,11 @@ class Api::UserPropertiesController < Api::ApiController def show property = Property.by_key(params[:id], nil, current_user.id) if property - render :json => jsonp(properties_to_json([property])) + respond_to do |format| + format.json { render :json => jsonp(properties_to_json([property])) } + format.xml { render :xml => properties_to_xml([property]) } + format.text { render :text => text_not_supported } + end else render_error('Not found', 404) end @@ -59,7 +67,11 @@ class Api::UserPropertiesController < Api::ApiController begin Property.clear(key, nil, current_user.id) property=Property.create(:prop_key => key, :text_value => value, :user_id => current_user.id) - render :json => jsonp(properties_to_json([property])) + respond_to do |format| + format.json { render :json => jsonp(properties_to_json([property])) } + format.xml { render :xml => properties_to_xml([property]) } + format.text { render :text => text_not_supported } + end rescue Exception => e render_error(e.message, 500) @@ -95,4 +107,12 @@ class Api::UserPropertiesController < Api::ApiController json end + def properties_to_xml(properties, xml=Builder::XmlMarkup.new(:indent => 0)) + xml.properties do + properties.each do |p| + p.to_xml(xml) + end + end + end + end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/metric.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/metric.rb index 54f0ff96ea3..204c8f49b83 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/metric.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/metric.rb @@ -281,6 +281,21 @@ class Metric < ActiveRecord::Base end end + def to_xml(options={}) + xml = Builder::XmlMarkup.new + xml.metric do + xml.key(name) + xml.name(short_name) + xml.description(description) + xml.domain(domain) + xml.qualitative(qualitative) + xml.direction(direction) + xml.user_managed(self.user_managed) + xml.val_type(val_type) + xml.hidden(hidden) + end + end + HUMANIZED_ATTRIBUTES = { :name => "key", :short_name => "name", diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/project_link.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/project_link.rb index ba01d3d08ec..1a11f230c4b 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/project_link.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/project_link.rb @@ -65,6 +65,14 @@ class ProjectLink < ActiveRecord::Base {'type' => link_type, 'name' => name, 'url' => href} end + def to_xml(xml) + xml.link do + xml.type(link_type) + xml.name(name) + xml.url(href) + end + end + def <=>(other) if name.nil? -1 diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/property.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/property.rb index 64a54f49eac..a66e0e452d5 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/property.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/property.rb @@ -137,6 +137,15 @@ class Property < ActiveRecord::Base java_definition && (java_definition.multi_values? || !java_definition.fields.blank?) end + def to_xml(xml=Builder::XmlMarkup.new(:indent => 0)) + xml.property do + xml.key(prop_key) + xml.value { xml.cdata!(value.to_s) } + Property.string_to_array_value(value.to_s).each { |v| xml.values { xml.cdata!(v) } } if multi_values? + end + xml + end + def java_definition @java_definition ||= Property.property_def(key) end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/rule.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/rule.rb index 1661b76911e..a5bd31ca656 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/rule.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/rule.rb @@ -206,6 +206,32 @@ class Rule < ActiveRecord::Base json end + def to_xml(profile, xml) + xml.rule do + xml.title(name) + xml.key(key) + xml.config_key(config_key) + xml.plugin(plugin_name) + xml.description { xml.cdata!(description) } if description + active_rule = nil + if profile + active_rule = profile.active_by_rule_id(id) + if active_rule + xml.priority(active_rule.priority_text) + xml.status('ACTIVE') + else + xml.priority(priority_text) + xml.status("INACTIVE") + end + else + xml.priority(priority_text) + end + parameters.each do |parameter| + parameter.to_xml(active_rule, xml) + end + end + end + def to_csv(profile) csv = [name.strip, plugin_rule_key, plugin_name] if profile diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/rules_parameter.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/rules_parameter.rb index 8f9fb439cc3..c1785dc0d13 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/rules_parameter.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/rules_parameter.rb @@ -35,6 +35,17 @@ class RulesParameter < ActiveRecord::Base json end + def to_xml(active_rule, xml) + xml.param do + xml.name(name) + xml.description { xml.cdata!(description) } if description + if active_rule + active_parameter = active_rule.active_param_by_param_id(id) + xml.value(active_parameter.value) if active_parameter + end + end + end + def <=>(other) name <=> other.name end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/widget_property.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/widget_property.rb index 998e51906ed..00220919af8 100644 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/widget_property.rb +++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/widget_property.rb @@ -57,6 +57,14 @@ class WidgetProperty < ActiveRecord::Base {:key => key, :value => text_value} end + def to_xml(xml=Builder::XmlMarkup.new(:indent => 0)) + xml.property do + xml.key(prop_key) + xml.value { xml.cdata!(text_value) } + end + xml + end + def self.text_to_value(text, type) PropertyType.text_to_value(text, type); end |