-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathReadMe.txt
121 lines (87 loc) · 5.83 KB
/
ReadMe.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
CrissCross
----------
CrissCross - alternative user interface for running SSRS reports
Project homepage: https://github.com/codeulike/crisscross
Copyright (C) 2011 - 2017 Ian Finch
Contact: www.codeulike.com [email protected]
Licensed under the GPLv2 - see License_Gpl2.txt
Description
-----------
CrissCross is an open-source ASP.NET application that provides an alternative front-end for running SSRS Reports.
That is, a way of running SSRS reports that is like the 'Report Manager' that comes with SSRS, but different
and more customisable. It is built using the standard ASP.NET ReportViewer component and the SSRS web services.
Compatibility
-------------
The latest version of CrissCross is designed to connect to SQL 2014 SSRS.
It should also work with older (and possibly newer) versions of SSRS with little or no adjustment.
It is written in ASP.NET 4.5 and can run on most recent versions of IIS and hence most Windows Servers.
Works with all the main browsers.
This Version
------------
Current version is a Beta version of the software - most of the core features are working and stable, but there may be occasional bugs (see documentation). It is however being used in production in at least two sites that I know of.
Getting Started
---------------
Setting up CrissCross is fairly simple, but does involve some knowledge of IIS and ASP.NET configuration.
So probably best to give it to someone who knows a bit of ASP.NET to set up.
CrissCross is designed to work with a minimum of configuration - basically you just tell it where your SSRS
server is and then off it goes. However there is additional optional configuration that can be peformed to
control how it behaves.
1a) If you are building from source, open the solution in Visual Studio and build.
Then publish the CrissCross Web App project to a temp folder from where you can deploy it.
- there is a Publishing Profile defined within the project that publishes to a folder
- or create your own profile to publish to a folder (or maybe straight to an IIS virtual folder)
1b) If you downloaded the 'PublishedWebApp' zip from github releases, it is already built/published. See below for details of copying it to IIS
2) Find an IIS server and create a CrissCross Virtual Directory on it.
If you use the IIS server on your SSRS server you've got more chance of getting impersonation working (see below)
but apart from that, any IIS server will do.
3) Copy the published CrissCross web app into your virtual directory
4) Make sure Windows Authentication is available.
In IIS 7 or later you might have to install it as an extra windows feature
http://www.iis.net/ConfigReference/system.webServer/security/authentication/windowsAuthentication
5) Make sure the ReportViewer component is installed on the server
If you're on the SSRS server, it'll be installed already, but if not you can install it using the
ReportViewer 2012 Runtime at https://www.microsoft.com/en-gb/download/details.aspx?id=35747
6) Edit some web.config settings:
In <appSettings> :
crisscross.ReportServerRootUrl
- set this to the url of the root folder of your SSRS reports folders. It will usually be something like
http://your-ssrs-server/reportserver . The ReportViewer component uses this to connect to the
SSRS server
crisscross.ReportServerWebServiceUrl
- set this to the url of the SSRS web service. It is usually something like:
http://your-ssrs-server/ReportServer/ReportService2005.asmx . CrissCross uses this to get the report
catalogue.
crisscross.ImpersonateLoggedOnUser
- CrissCross can either run the reports as the logged in user, or run as a fixed user. Turning off
Impersonation and using a Fixed User is easier to get started with, but turning Impersonation on makes
CrissCross more useful. Note that Impersonation works best when CrissCross is running on the SSRS
server itself. See the documentation at https://github.com/codeulike/crisscross/wiki/Impersonation-Mode for more details.
crisscross.FixedSsrsUsername
crisscross.FixedSsrsDomain
crisscross.FixedSsrsPassword
- If ImpersonationLoggedOnUser is false, these settings must be set to a valid domain/username/password for
running SSRS reports. For best results, set the web app's Application Pool (in IIS) to run under the same account.
crisscross.UseReportHistory
- CrissCross queries information from the SSRS Report History Log (see connection strings, below). If you'd rather
not do that, set this value to false.
crisscross.ReportHistoryFormat
- If UseReportHistory is true, this tells CrissCross what format to read the history in. The default is "2008" (for
SSRS 2008). If you are using SSRS 2005 then set it to "2005".
Also, further down in the web config:
<identity impersonate="true/false"/>
- This must be set to the same true/false value as ImpersonateLoggedOnUser
In <ConnectionStrings> :
ReportServerDb
- Set this to point at your SSRS database (the database that holds SSRS settings). It will usually be a database
called ReportServer on the SSRS server. CrissCross uses this to fetch info about previous report runs from the
report log - hence only the datareader role in necessary for the SQL user.
7) If using Impersonation Mode, make sure Integreated Windows Authentication is turned on in IIS.
See: https://github.com/codeulike/crisscross/wiki/Impersonation-Mode
8) That should be it; use a browser to navigate to the virtual directory and CrissCross should start running.
Troubleshooting
---------------
CrissCross logs general info to log.txt in the App_Data folder
Elmah is used for error logging, so check Elmah if you are having problems:
- On the local server, browse to (your virtual folder)/elmah.axd to see the error log.
- Or see the XML files in the App_Data\ErrorLog folder.
For documentation, discussions and to log bugs to the Issue Tracker, please go to https://github.com/codeulike/crisscross