Click here to Skip to main content
15,895,084 members
Articles / Web Development / ASP.NET

An Open Source RDL Engine

Rate me:
Please Sign up or sign in to vote.
4.77/5 (12 votes)
20 Dec 2010CPOL3 min read 83.8K   3.5K   55  
An Open Source RDL engine for rendering reports to WinForms or ASP.NET
using System;
using System.Collections.Generic;
using System.Text;
using System.Xml;

namespace RdlEngine
{
    class DataSource : ReportElement
    {
        private string _name = null;
        private bool _transaction = false;
        private ConnectionProperties _connectionProperties = null;
        private string _dataSourceReference = null;
        private System.Data.SqlClient.SqlConnection _sqlConn = null;
        private System.Data.SqlClient.SqlTransaction _sqlTran = null;

        public DataSource(XmlNode node, ReportElement parent)
            : base(node, parent)
        {
        }

        protected override void ParseAttribute(XmlNode attr)
        {
            switch (attr.Name.ToLower())
            {
                case "name":
                    _name = attr.InnerText;
                    break;
                case "transaction":
                    _transaction = bool.Parse(attr.InnerText);
                    break;
                case "connectionproperties":
                    _connectionProperties = new ConnectionProperties(attr, this);
                    break;
                case "datasourcereference":
                    _dataSourceReference = attr.InnerText;
                    break;
                default:
                    break;
            }
        }

        public System.Data.Common.DbConnection Connect()
        {
            if (_connectionProperties.DataProvider == "SQL")
            {
                _sqlConn = new System.Data.SqlClient.SqlConnection();
                _sqlConn.ConnectionString = _connectionProperties.ConnectString;
                if (_connectionProperties.Promt != null)
                {
                    RdlRuntime.CredentialsPromptEventArgs args = new RdlRuntime.CredentialsPromptEventArgs();
                    args.Prompt = _connectionProperties.Promt;
                    Report.OnCredentialsPrompt(args);

                    _sqlConn.ConnectionString += ";UID=" + args.UserID + ";PWD=" + args.Password;
                }
                _sqlConn.Open();

                if (_transaction)
                    _sqlTran = _sqlConn.BeginTransaction();
            }
            return null;
        }

        public string Name
        {
            get { return _name; }
        }

        public System.Data.SqlClient.SqlConnection sqlConn
        {
            get { return _sqlConn; }
        }

        public ConnectionProperties ConnectionProperties
        {
            get { return _connectionProperties; }
        }
    }
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Software Developer (Senior) Sawiki Software
United States United States
I have been a professional software developer for 25+ years, most of it supporting the business community of Maine. I have been working with MS dotnet since 1.0 beta. I organized Sawiki Software LLC as an outlet for some open source software that I have been working on.

Comments and Discussions