org.sonar.plugins.findbugs.FindbugsSecurityAuditProfile Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sonar-findbugs-plugin Show documentation
Show all versions of sonar-findbugs-plugin Show documentation
FindBugs is a program that uses static analysis to look for bugs in Java code. It can detect a variety of common coding mistakes, including thread synchronization problems, misuse of API methods.
The newest version!
/*
* SonarQube Findbugs Plugin
* Copyright (C) 2012 SonarSource
* [email protected]
*
* 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, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
*/
package org.sonar.plugins.findbugs;
import org.sonar.api.profiles.ProfileDefinition;
import org.sonar.api.profiles.RulesProfile;
import org.sonar.api.utils.ValidationMessages;
import org.sonar.plugins.java.Java;
import java.io.InputStreamReader;
import java.io.Reader;
/**
* Security rules including informational rules. This profile is intend for in depth security code review.
*/
public class FindbugsSecurityAuditProfile extends ProfileDefinition {
private static final String FINDBUGS_SECURITY_AUDIT_PROFILE_NAME = "FindBugs Security Audit";
private final FindbugsProfileImporter importer;
public FindbugsSecurityAuditProfile(FindbugsProfileImporter importer) {
this.importer = importer;
}
@Override
public RulesProfile createProfile(ValidationMessages messages) {
Reader findbugsProfile = new InputStreamReader(this.getClass().getResourceAsStream(
"/org/sonar/plugins/findbugs/profile-findbugs-security-audit.xml"));
RulesProfile profile = importer.importProfile(findbugsProfile, messages);
profile.setLanguage(Java.KEY);
profile.setName(FINDBUGS_SECURITY_AUDIT_PROFILE_NAME);
return profile;
}
}