data:image/s3,"s3://crabby-images/44758/44758fd304c6fae67f2a599d1b705535db241004" alt="image image"
(this is a cross posted from the LightSwitch Help Website)
Integrating a LightSwitch application into DotNetNuke has been covered before in Deploy Your LightSwitch Application As A DotNetNuke Module. The problem with that solution is:
- It requires a lot of assemblies to be added to your DotNetNuke site
- It requires edits to your DotNetNuke site’s web.config file
- You can only deploy one LightSwitch application to a DotNetNuke site
The third one is usually a show-stopper. This method, using IFrames, gets around all those problems.
The Application
data:image/s3,"s3://crabby-images/97bbc/97bbc1b25cc6cb7443e5f27d3f6c88646a3acdf5" alt="image image"
We start with the application used in It Is Easy To Display Counts And Percentages In LightSwitch.
data:image/s3,"s3://crabby-images/82136/82136e61c67457827c1ce05807c25126af82c23b" alt="image image"
In that application, we wire-up a method on the PhoneCall table and add the following code:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.LightSwitch;
namespace LightSwitchApplication
{
public partial class PhoneCall
{
partial void PhoneCall_Created()
{
MessageTakenBy = this.Application.User.Name;
}
}
}
That is all that is required to integrate the application into DotNetNuke. When a user is logged-in, DotNetNuke will pass the authenticated User Name to the LightSwitch application, so it can save the user that creates the Phone Call record.
data:image/s3,"s3://crabby-images/fa038/fa038da194f5714adc759989b12541bb691a0ce6" alt="image image"
We go into Properties and turn on Forms Authentication.
data:image/s3,"s3://crabby-images/b7400/b740078cc8ffe8879bc06a4da112ef97d07e4199" alt="image image"
We also set the application to be a Web Application that is deployed on IIS.
data:image/s3,"s3://crabby-images/2911e/2911ea8e17407bd5de9cffb224def75b72c87c9e" alt="image image"
In the Visual Studio Configuration Manager, we switch to Release.
data:image/s3,"s3://crabby-images/b05d3/b05d31fd56f14be6fe65c725c142b058681ca9b1" alt="image image"
We then Publish the application.
data:image/s3,"s3://crabby-images/a1dc3/a1dc3067c30a4e251e5fed1434f7898396c1ec2d" alt="image image"
When we get to the database screen, we specify the DotNetNuke database.
Calling The LightSwitch Application From DotNetNuke
data:image/s3,"s3://crabby-images/835e3/835e3b6f057878081f3ba53f97313bcb0f27dba1" alt="image image"
We follow the directions in this post by LightSwitch team member Valerie Andersen:
http://social.msdn.microsoft.com/Forums/en-US/lightswitchgeneral/thread/60c76dde-07dd-48f7-8aed-f7aec66c47d4
Essentially we need to:
- Copy the Machine Key from the DotNetNuke web.config to the LightSwitch application
- Make some more minor edits to the web.config of the LightSwitch application
data:image/s3,"s3://crabby-images/566b3/566b328854913b2126a372d34bee6aa3ea325ddb" alt="image image"
Next, we download and install the DotNetNuke IFrame module from: http://dnniframe.codeplex.com.
data:image/s3,"s3://crabby-images/773d6/773d6d14e70a2e560f0807caa18843c59be3d4c5" alt="image image"
We configure the module to point to the LightSwitch application…
data:image/s3,"s3://crabby-images/bf5dd/bf5dd978e173b224d519b49732ec0c7e28c16566" alt="image image"
… and it just works.
data:image/s3,"s3://crabby-images/45a32/45a3227d29e25a534e05105310f46d5051663e20" alt="image image"
The sample application also contains the LightSwitch Filter Extension (covered in Using The LightSwitch Filter Extension).
Download
You can download the code at this link.