Products

Solutions

Resources

Partners

Community

About

New Community Website

Ordinarily, you'd be at the right spot, but we've recently launched a brand new community website... For the community, by the community.

Yay... Take Me to the Community!

The Community Blog is a personal opinion of community members and by no means the official standpoint of DNN Corp or DNN Platform. This is a place to express personal thoughts about DNNPlatform, the community and its ecosystem. Do you have useful information that you would like to share with the DNN Community in a featured article or blog? If so, please contact .

The use of the Community Blog is covered by our Community Blog Guidelines - please read before commenting or posting.


Backport AddScheduleItemSettings

Overview

jmb_ScheduleItem_settings.jpgA couple months ago, in "The quest for the DotNetNuke Holy Grail", I blogged about using ScheduleItemSettings for passing data to a SchedulerClient.  To make this work required a minor modification to the DotNetNuke core which was integrated into the 3.3/4.3 releases.  There are still some people who are running older versions of DotNetNuke where this modification might still be useful.  While we encourage everyone to upgrade to the latest DotNetNuke version, we also realize that sometimes business realities prevent this from happening.

For the people who cannot upgrade, I have included the modifications necessary to allow your scheduled task to take advantage of the ScheduleItemSettings.  When I built this solution for a client, I created a simple module administration screen that allowed the user to save the appropriate settings to the ScheduleItemSettings table.  By including the following code with an editor, you can use the module installation procedures to add the appropriate stored procedure and DAL methods.  This will require you to add this code to every Scheduler module, but it provides a simple way to add it to your site without modifying the core.

SqlDataProvider Script

-- ======================================================
-- Stored Procedures
-- ======================================================

IF EXISTS (
    SELECT *
    FROM sysobjects
    WHERE id = object_id(N'{databaseOwner}{objectQualifier}AddScheduleItemSetting')
    AND OBJECTPROPERTY(id, N'IsProcedure') = 1
)
    DROP PROCEDURE {databaseOwner}{objectQualifier}AddScheduleItemSetting
GO

CREATE PROCEDURE {databaseOwner}{objectQualifier}AddScheduleItemSetting
    @ScheduleID int,
    @Name nvarchar(50),
    @Value nvarchar(256)
as

IF EXISTS (
    SELECT *
    FROM {databaseOwner}{objectQualifier}ScheduleItemSettings
    WHERE ScheduleID = @ScheduleID
    AND SettingName = @Name
)
BEGIN
    UPDATE {databaseOwner}{objectQualifier}ScheduleItemSettings
    SET SettingValue = @Value
    WHERE ScheduleID = @ScheduleID
    AND SettingName = @Name
END
ELSE
BEGIN
    INSERT INTO {databaseOwner}{objectQualifier}ScheduleItemSettings (
        ScheduleID,
        SettingName,
        Settingvalue
    )
    VALUES (
        @ScheduleID,
        @Name,
        @Value
    )
END

GO

SqlDataProvider Concrete Method

Public Overrides Sub AddScheduleItemSetting(ByVal ScheduleID As Integer, ByVal Name As String, ByVal Value As String)
    SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "AddScheduleItemSetting", ScheduleID, Name, Value)
End Sub

DataProvider Abstract Method

 Public MustOverride Sub AddScheduleItemSetting(ByVal ScheduleID As Integer, ByVal Name As String, ByVal Value As String)

Comments

There are currently no comments, be the first to post one.

Comment Form

Only registered users may post comments.

NewsArchives


Aderson Oliveira (22)
Alec Whittington (11)
Alessandra Daniels (3)
Alex Shirley (10)
Andrew Hoefling (3)
Andrew Nurse (30)
Andy Tryba (1)
Anthony Glenwright (5)
Antonio Chagoury (28)
Ash Prasad (37)
Ben Schmidt (1)
Benjamin Hermann (25)
Benoit Sarton (9)
Beth Firebaugh (12)
Bill Walker (36)
Bob Kruger (5)
Bogdan Litescu (1)
Brian Dukes (2)
Brice Snow (1)
Bruce Chapman (20)
Bryan Andrews (1)
cathal connolly (55)
Charles Nurse (163)
Chris Hammond (213)
Chris Paterra (55)
Clint Patterson (108)
Cuong Dang (21)
Daniel Bartholomew (2)
Daniel Mettler (181)
Daniel Valadas (48)
Dave Buckner (2)
David Poindexter (12)
David Rodriguez (3)
Dennis Shiao (1)
Doug Howell (11)
Erik van Ballegoij (30)
Ernst Peter Tamminga (80)
Francisco Perez Andres (17)
Geoff Barlow (12)
George Alatrash (12)
Gifford Watkins (3)
Gilles Le Pigocher (3)
Ian Robinson (7)
Israel Martinez (17)
Jan Blomquist (2)
Jan Jonas (3)
Jaspreet Bhatia (1)
Jenni Merrifield (6)
Joe Brinkman (274)
John Mitchell (1)
Jon Henning (14)
Jonathan Sheely (4)
Jordan Coopersmith (1)
Joseph Craig (2)
Kan Ma (1)
Keivan Beigi (3)
Kelly Ford (4)
Ken Grierson (10)
Kevin Schreiner (6)
Leigh Pointer (31)
Lorraine Young (60)
Malik Khan (1)
Matt Rutledge (2)
Matthias Schlomann (16)
Mauricio Márquez (5)
Michael Doxsey (7)
Michael Tobisch (3)
Michael Washington (202)
Miguel Gatmaytan (3)
Mike Horton (19)
Mitchel Sellers (40)
Nathan Rover (3)
Navin V Nagiah (14)
Néstor Sánchez (31)
Nik Kalyani (14)
Oliver Hine (1)
Patricio F. Salinas (1)
Patrick Ryan (1)
Peter Donker (54)
Philip Beadle (135)
Philipp Becker (4)
Richard Dumas (22)
Robert J Collins (5)
Roger Selwyn (8)
Ruben Lopez (1)
Ryan Martinez (1)
Sacha Trauwaen (1)
Salar Golestanian (4)
Sanjay Mehrotra (9)
Scott McCulloch (1)
Scott Schlesier (11)
Scott Wilkinson (3)
Scott Willhite (97)
Sebastian Leupold (80)
Shaun Walker (237)
Shawn Mehaffie (17)
Stefan Cullmann (12)
Stefan Kamphuis (12)
Steve Fabian (31)
Steven Fisher (1)
Tony Henrich (3)
Torsten Weggen (3)
Tycho de Waard (4)
Vicenç Masanas (27)
Vincent Nguyen (3)
Vitaly Kozadayev (6)
Will Morgenweck (40)
Will Strohl (180)
William Severance (5)
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out