c# - que - Genere informes mediante programación utilizando la API TFS y SSRS
que es reporting services (1)
¿Existe un enfoque simple en la generación de informes, ya sea en formatos PDF, Excel, Word o TIFF utilizando la API TFS y SSRS? Puedo generar los informes manualmente seleccionando los parámetros de los cuadros combinados utilizando el panel SSRS para TFS, pero me gustaría incluir un botón exportar a mi aplicación web para poder evitar fácilmente Team Web Access para generar informes. ¿Algunas ideas?
He leído en esta publicación que podría usar la clase ReportExecutionService
de SSRS, por lo que me preguntaba si podría usarse desde el servidor TFS.
He importado el espacio de nombres utilizando esta referencia de servicio web: http://<TFS server>/reportserver/ReportExecution2005.asmx
He descubierto una forma de generar informes utilizando el servicio web ReportExecutionService
. Siempre que se haya agregado una referencia de servicio web al proyecto, esto generará un archivo con los parámetros especificados. Aquí las fechas de inicio y final se proporcionan como parámetros y el informe se genera utilizando el método Render () .
private void GenerateReport()
{
ReportExecutionService rs = new ReportExecutionService();
rs.Credentials = System.Net.CredentialCache.DefaultCredentials;
rs.Url = "http://<TFS server name>/reportserver/ReportExecution2005.asmx";
// Render arguments
byte[] result = null;
string reportPath = @"<SSRS report path>";
string format = "PDF";
string historyID = null;
string devInfo = @"<DeviceInfo><Toolbar>False</Toolbar></DeviceInfo>";
// Prepare report parameter.
ParameterValue[] parameters = new ParameterValue[2];
parameters[0] = new ParameterValue();
parameters[0].Name = "StartDateParam";
parameters[0].Value = "2012-06-01 00:00:00";
parameters[1] = new ParameterValue();
parameters[1].Name = "EndDateParam";
parameters[1].Value = "2012-09-01 00:00:00";
parameters[2] = new ParameterValue();
parameters[2].Name = "AreaParam";
parameters[2].Value = "[Work Item].[Area Hierarchy].[All]";
parameters[3] = new ParameterValue();
parameters[3].Name = "WorkItemTypeParam";
parameters[3].Value = "[Work Item].[System_WorkItemType].&[Task]";
parameters[4] = new ParameterValue();
parameters[4].Name = "StateParam";
parameters[4].Value = "[Work Item].[System_State].&[Active]";
parameters[5] = new ParameterValue();
parameters[5].Name = "TrendLineParam";
parameters[5].Value = "both";
DataSourceCredentials[] credentials = null;
string showHideToggle = null;
string encoding;
string mimeType;
string extension;
Warning[] warnings = null;
ParameterValue[] reportHistoryParameters = null;
string[] streamIDs = null;
ExecutionInfo execInfo = new ExecutionInfo();
ExecutionHeader execHeader = new ExecutionHeader();
rs.ExecutionHeaderValue = execHeader;
execInfo = rs.LoadReport(reportPath, historyID);
var parameters_ = rs.GetExecutionInfo().Parameters;
rs.SetExecutionParameters(parameters, "en-us");
String SessionId = rs.ExecutionHeaderValue.ExecutionID;
Console.WriteLine("SessionID: {0}", rs.ExecutionHeaderValue.ExecutionID);
try
{
result = rs.Render(format, devInfo, out extension, out encoding, out mimeType, out warnings, out streamIDs);
execInfo = rs.GetExecutionInfo();
Console.WriteLine("Execution date and time: {0}", execInfo.ExecutionDateTime);
}
catch (SoapException e)
{
Console.WriteLine(e.Detail.OuterXml);
}
// Write the contents of the report to an MHTML file.
try
{
FileStream stream = File.Create("report.pdf", result.Length);
Console.WriteLine("File created.");
stream.Write(result, 0, result.Length);
Console.WriteLine("Result written to the file.");
stream.Close();
}
catch (Exception e)
{
Console.WriteLine(e.Message);
}
}
Por cierto, los valores establecidos para los parámetros son consultas MDX y aún no he descubierto cómo configurar un AreaPath específico, por lo que por ahora solo puedo hacer una lista de ''Todos''.