<% @ Language=VBScript %> <% Option Explicit %> <% '**************************************************************************************** '** Copyright Notice '** '** Web Wiz Forums(TM) '** http://www.webwizforums.com '** '** Copyright (C)2001-2008 Web Wiz(TM). All Rights Reserved. '** '** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS UNDER LICENSE FROM 'WEB WIZ'. '** '** IF YOU DO NOT AGREE TO THE LICENSE AGREEMENT THEN 'WEB WIZ' IS UNWILLING TO LICENSE '** THE SOFTWARE TO YOU, AND YOU SHOULD DESTROY ALL COPIES YOU HOLD OF 'WEB WIZ' SOFTWARE '** AND DERIVATIVE WORKS IMMEDIATELY. '** '** If you have not received a copy of the license with this work then a copy of the latest '** license contract can be found at:- '** '** http://www.webwizguide.com/license '** '** For more information about this software and for licensing information please contact '** 'Web Wiz' at the address and website below:- '** '** Web Wiz, Unit 10E, Dawkins Road Industrial Estate, Poole, Dorset, BH15 4JD, England '** http://www.webwizguide.com '** '** Removal or modification of this copyright notice will violate the license contract. '** '**************************************************************************************** '*************************** SOFTWARE AND CODE MODIFICATIONS **************************** '** '** MODIFICATION OF THE FREE EDITIONS OF THIS SOFTWARE IS A VIOLATION OF THE LICENSE '** AGREEMENT AND IS STRICTLY PROHIBITED '** '** If you wish to modify any part of this software a license must be purchased '** '**************************************************************************************** 'Set the response buffer to true as we maybe redirecting Response.Buffer = True 'Dimension variables Dim rsNumOfPosts 'Holds the database recordset for the number of posts the user has made Dim rsForum 'Holds the forum for order Dim strMode 'Holds the mode of the page Dim lngTopicID 'Holds the topic ID number to return to Dim lngPollID 'Holds the poll ID number if there is one Dim lngDelMsgAuthorID 'Holds the deleted message Author ID Dim lngNumOfPosts 'Holds the number of posts the user has made 'If in demo mode redirect If blnDemoMode Then Call closeDatabase() Response.Redirect("insufficient_permission.asp?M=DEMO" & strQsSID3) End If 'If the user is user is using a banned IP redirect to an error page If bannedIP() Then 'Clean up Call closeDatabase() 'Redirect Response.Redirect("insufficient_permission.asp?M=IP" & strQsSID3) End If 'Read in the message ID number to be deleted lngTopicID = CLng(Request("TID")) 'Initliase the SQL query to get the topic and forumID from the database strSQL = "SELECT " & strDbTable & "Topic.Forum_ID " & _ "FROM " & strDbTable & "Topic " & strDBNoLock & " " & _ "WHERE " & strDbTable & "Topic.Topic_ID = " & lngTopicID & ";" 'Query the database rsCommon.Open strSQL, adoCon 'If there is a record returned read in the forum ID If NOT rsCommon.EOF Then intForumID = CInt(rsCommon("Forum_ID")) End If 'Clean up rsCommon.Close 'Call the moderator function and see if the user is a moderator If blnAdmin = False Then blnModerator = isModerator(intForumID, intGroupID) 'Check to make sure the user is deleting the post is a moderator or the forum adminstrator If blnAdmin = True OR blnModerator = True Then 'See if there is a poll, if there is get the poll ID and delete 'Initalise the strSQL variable strSQL = "SELECT " & strDbTable & "Topic.Poll_ID " & _ "FROM " & strDbTable & "Topic " & strDBNoLock & " " & _ "WHERE " & strDbTable & "Topic.Topic_ID = " & lngTopicID & ";" 'Query the database rsCommon.Open strSQL, adoCon 'Get the Poll ID If NOT rsCommon.EOF Then lngPollID = CLng(rsCommon("Poll_ID")) 'Close the recordset rsCommon.Close 'Get the Posts to be deleted from the database strSQL = "SELECT " & strDbTable & "Thread.* " & _ "FROM " & strDbTable & "Thread " & strDBNoLock & " " & _ "WHERE " & strDbTable & "Thread.Topic_ID = " & lngTopicID & ";" 'Query the database rsCommon.Open strSQL, adoCon 'Get the number of posts the user has made and take one away Set rsNumOfPosts = Server.CreateObject("ADODB.Recordset") 'Loop through all the posts for the topic and delete them Do While NOT rsCommon.EOF 'First we need to delete any entry in the GuestName table incase this was a guest poster posting the message strSQL = "DELETE FROM " & strDbTable & "GuestName " & strRowLock & " WHERE " & strDbTable & "GuestName.Thread_ID = " & CLng(rsCommon("Thread_ID")) & ";" 'Excute SQL adoCon.Execute(strSQL) 'Initalise the strSQL variable with an SQL statement to query the database to get the number of posts the user has made strSQL = "SELECT " & strDbTable & "Author.Author_ID, " & strDbTable & "Author.No_of_posts " & _ "FROM " & strDbTable & "Author " & strDBNoLock & " " & _ "WHERE " & strDbTable & "Author.Author_ID = " & CLng(rsCommon("Author_ID")) & ";" 'Query the database rsNumOfPosts.Open strSQL, adoCon 'If there is a record returned by the database then read in the no of posts and decrement it by 1 If NOT rsNumOfPosts.EOF Then 'Read in the no of posts the user has made and username lngNumOfPosts = CLng(rsNumOfPosts("No_of_posts")) 'Decrement by 1 unless the number of posts is already 0 If lngNumOfPosts > 0 Then 'decrement the number of posts by 1 lngNumOfPosts = lngNumOfPosts - 1 'Initalise the SQL string with an SQL update command to update the number of posts the user has made strSQL = "UPDATE " & strDbTable & "Author " & strRowLock & " " & _ "SET " & strDbTable & "Author.No_of_posts = " & lngNumOfPosts & " " & _ "WHERE " & strDbTable & "Author.Author_ID = " & CLng(rsCommon("Author_ID")) & ";" 'Write the updated number of posts to the database adoCon.Execute(strSQL) End If End If 'Close the recordset rsNumOfPosts.Close 'Move to the next record rsCommon.MoveNext Loop 'Delete the posts in this topic strSQL = "DELETE FROM " & strDbTable & "Thread " & strRowLock & " WHERE " & strDbTable & "Thread.Topic_ID = " & lngTopicID & ";" 'Write to database adoCon.Execute(strSQL) 'Delete the Poll in this topic, if there is one If lngPollID > 0 Then 'Delete the Poll choices strSQL = "DELETE FROM " & strDbTable & "PollChoice " & strRowLock & " WHERE " & strDbTable & "PollChoice.Poll_ID = " & lngPollID & ";" 'Write to database adoCon.Execute(strSQL) 'Delete the Poll Votes strSQL = "DELETE FROM " & strDbTable & "PollVote " & strRowLock & " WHERE " & strDbTable & "PollVote.Poll_ID = " & lngPollID & ";" 'Write to database adoCon.Execute(strSQL) 'Delete the Poll strSQL = "DELETE FROM " & strDbTable & "Poll " & strRowLock & " WHERE " & strDbTable & "Poll.Poll_ID = " & lngPollID & ";" 'Write to database adoCon.Execute(strSQL) End If 'Delete the topic from the database 'Initalise the strSQL variable with an SQL statement to get the topic from the database strSQL = "DELETE FROM " & strDbTable & "Topic " & strRowLock & " WHERE " & strDbTable & "Topic.Topic_ID = " & lngTopicID & ";" 'Write the updated date of last post to the database adoCon.Execute(strSQL) 'Reset Server Objects rsCommon.Close Set rsNumOfPosts = Nothing End If 'Update the number of topics and posts in the database Call updateForumStats(intForumID) 'Reset main server variables Call closeDatabase() 'If from topic index and not tool options redirect back If Request.QueryString("PN") <> "" Then Response.Redirect("forum_topics.asp?FID=" & intForumID & "&PN=" & Server.URLEncode(Request.QueryString("PN")) & strQsSID3) %>