mirror of
https://bitbucket.org/smil3y/kde-extraapps.git
synced 2025-02-26 11:52:54 +00:00
149 lines
5.2 KiB
Java
149 lines
5.2 KiB
Java
import java.io.*;
|
|
import java.sql.*;
|
|
import java.lang.reflect.*;
|
|
import javax.servlet.*;
|
|
import javax.servlet.http.*;
|
|
|
|
public class KdeCommitsServlet extends HttpServlet
|
|
{
|
|
public void init()
|
|
{
|
|
String dbHost = "";
|
|
String dbName = "";
|
|
String username = "";
|
|
String password = "";
|
|
|
|
try
|
|
{
|
|
Class.forName("com.mysql.jdbc.Driver");
|
|
}
|
|
catch(ClassNotFoundException e)
|
|
{
|
|
System.out.println("Error loading driver:" + e.getMessage());
|
|
}
|
|
|
|
try
|
|
{
|
|
String url ="jdbc:mysql://" + dbHost + ":3306/" + dbName;
|
|
conn = DriverManager.getConnection(url, username, password);
|
|
}
|
|
catch(SQLException e)
|
|
{
|
|
String err1Msg = e.getMessage();
|
|
}
|
|
}
|
|
|
|
public void doGet(HttpServletRequest request, HttpServletResponse response)
|
|
{
|
|
String operation = null;
|
|
Class[] paramTypes = null;
|
|
Object[] paramValues = null;
|
|
|
|
PrintWriter out = null;
|
|
try
|
|
{
|
|
out = response.getWriter();
|
|
}
|
|
catch (IOException e)
|
|
{
|
|
System.out.println("Error acquiring writer:" + e.getMessage());
|
|
}
|
|
|
|
try
|
|
{
|
|
|
|
if (request.getParameterMap().size() == 0)
|
|
{
|
|
response.setContentType("text/html");
|
|
out.println("No operation supplied !");
|
|
return;
|
|
}
|
|
|
|
response.setContentType("text/plain");
|
|
operation = request.getParameter("op");
|
|
paramTypes = new Class[request.getParameterMap().size()];
|
|
paramValues = new Object[paramTypes.length];
|
|
|
|
paramTypes[0] = PrintWriter.class;
|
|
paramValues[0] = out;
|
|
|
|
for (int i = 0; i < paramValues.length - 1; ++i)
|
|
{
|
|
paramTypes[i+1] = String.class;
|
|
paramValues[i+1] = request.getParameter("p" + i);
|
|
}
|
|
|
|
Method method = getClass().getDeclaredMethod(operation, paramTypes);
|
|
method.invoke(this, paramValues);
|
|
}
|
|
catch (NoSuchMethodException e)
|
|
{
|
|
response.setContentType("text/html");
|
|
out.println("Unsupported operation " + operation + " with " + paramTypes.length + " String parameters !");
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
response.setContentType("text/html");
|
|
out.println("Exception: " + e.getClass().getName() + " " + e.getMessage());
|
|
}
|
|
}
|
|
|
|
public void allProjectsInfo(PrintWriter out) throws SQLException
|
|
{
|
|
String query = "select name, commit_subject, krazy_report, krazy_identifier, icon, add_in_view from projects";
|
|
Statement stmt = conn.createStatement();
|
|
ResultSet res = stmt.executeQuery(query);
|
|
printResultSet(out, res);
|
|
}
|
|
|
|
public void topActiveProjects(PrintWriter out, String n) throws SQLException
|
|
{
|
|
String query = "select p.name, count(*) from projects p, commits c where INSTR(c.path, p.commit_subject) > 0 group by p.commit_subject order by count(*) desc";
|
|
if (!n.equals("0"))
|
|
query = query + " limit 0 , " + n;
|
|
Statement stmt = conn.createStatement();
|
|
ResultSet res = stmt.executeQuery(query);
|
|
printResultSet(out, res);
|
|
}
|
|
|
|
public void topProjectDevelopers(PrintWriter out, String project, String n) throws SQLException
|
|
{
|
|
String query;
|
|
if (!project.equals(""))
|
|
query = "select d.full_name, d.svn_account, d.first_commit, d.last_commit, count(*) from projects p, commits c, developers d where INSTR(c.path, p.commit_subject) > 0 and d.svn_account = c.svn_account and p.name = '" + project + "' group by d.full_name, p.name order by count(*) desc";
|
|
else
|
|
query = "select d.full_name, d.svn_account, d.first_commit, d.last_commit, count(*) from commits c, developers d where d.svn_account = c.svn_account group by d.full_name order by count(*) desc";
|
|
if (!n.equals("0"))
|
|
query = query + " limit 0 , " + n;
|
|
Statement stmt = conn.createStatement();
|
|
ResultSet res = stmt.executeQuery(query);
|
|
printResultSet(out, res);
|
|
}
|
|
|
|
public void commitHistory(PrintWriter out, String project, String n) throws SQLException
|
|
{
|
|
String query;
|
|
if (!project.equals(""))
|
|
query = "select date(c.date_time) date, count(*) from projects p, commits c where INSTR(c.path, p.commit_subject) > 0 and p.name = '" + project + "' group by date order by date desc";
|
|
else
|
|
query = "select date(c.date_time) date, count(*) from commits c group by date order by date desc";
|
|
if (!n.equals("0"))
|
|
query = query + " limit 0 , " + n;
|
|
Statement stmt = conn.createStatement();
|
|
ResultSet res = stmt.executeQuery(query);
|
|
printResultSet(out, res);
|
|
}
|
|
|
|
private void printResultSet(PrintWriter out, ResultSet res) throws SQLException
|
|
{
|
|
int count = res.getMetaData().getColumnCount();
|
|
while(res.next())
|
|
{
|
|
for (int i = 1; i < count; ++i)
|
|
out.print(res.getObject(i) + ";");
|
|
out.println(res.getObject(count));
|
|
}
|
|
}
|
|
|
|
private Connection conn;
|
|
}
|