All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.qualinsight.plugins.sonarqube.badges.ws.measure.MeasureBadgeAction Maven / Gradle / Ivy

Go to download

This plugin adds a webservice to SonarQube that allows the retrieval of different types of badges that display as a SVG image the quality of a project or a view.

There is a newer version: 3.0.1
Show newest version
/*
 * qualinsight-plugins-sonarqube-badges
 * Copyright (c) 2015-2016, QualInsight
 * http://www.qualinsight.com/
 *
 * This program is free software: you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation, either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this program. If not, you can retrieve a copy
 * from .
 */
package com.qualinsight.plugins.sonarqube.badges.ws.measure;

import org.sonar.api.server.ServerSide;
import org.sonar.api.server.ws.WebService;
import org.sonar.api.server.ws.WebService.Action;
import org.sonar.api.server.ws.WebService.Controller;
import org.sonar.api.server.ws.WebService.NewAction;
import org.sonar.api.server.ws.WebService.NewController;

/**
 * Creates {@link Action} for measure badge {@link WebService} {@link Controller}.
 *
 * @author Michel Pawlak
 */
@ServerSide
public class MeasureBadgeAction {

    private static final String RESPONSE_EXAMPLE_FILE = "/com/qualinsight/plugins/sonarqube/badges/ws/measure/example.svg";

    private static final String SINCE_VERSION = "2.0.0";

    private MeasureBadgeRequestHandler measureBadgeRequestHandler;

    /**
     * {@link MeasureBadgeAction} IoC constructor
     *
     * @param measureBadgeRequestHandler request handler to be bound to the action
     */
    public MeasureBadgeAction(final MeasureBadgeRequestHandler measureBadgeRequestHandler) {
        this.measureBadgeRequestHandler = measureBadgeRequestHandler;
    }

    /**
     * Adds the action to a provided controller
     *
     * @param controller the action needs to be added to
     */
    public void createOn(final NewController controller) {
        final NewAction action = controller.createAction("measure")
            .setDescription("Retrieves a measure for a project as a SVG image.")
            .setHandler(this.measureBadgeRequestHandler)
            .setSince(SINCE_VERSION)
            .setResponseExample(getClass().getResource(RESPONSE_EXAMPLE_FILE));
        action.createParam("key")
            .setDescription("Key of the project")
            .setExampleValue("org.codehaus.sonar:sonar")
            .setRequired(true);
        action.createParam("metric")
            .setDescription("measured metric to be retrieved")
            .setExampleValue("coverage")
            .setRequired(true);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy