%@ Language=VBScript %>
<% Option Explicit %>
<%
'-------------------------------------------------------------------------
' Ftp_WelcomeMsg.asp: Set the messages to the FTP Sites/Service
'
' Copyright (c) Microsoft Corporation. All rights reserved.
'
' Date Description
' 25-10-2000 Created date
' 15-01-2000 Modified for new Framework
'-------------------------------------------------------------------------
%>
<%
'-------------------------------------------------------------------------
' Form Variables
'-------------------------------------------------------------------------
Dim F_strWelcomeMsg 'holds Welcome message
Dim F_strExitMsg 'holds Exit message
Dim F_strMaxConMsg 'holds Max connections message
'Dim F_AllSites 'holds value for the selected option button
Dim FTPInstalled 'holds boolean whether FTP service is installed or not
'-------------------------------------------------------------------------
' Global Variables
'-------------------------------------------------------------------------
Dim G_objService 'holds the object locator
Dim G_objSites 'holds the site/service object
'-------------------------------------------------------------------------
' Start of localization content
'-------------------------------------------------------------------------
Dim L_MESSAGETASKTITLETEXT
Dim L_WELCOMEMSG
Dim L_EXITMSG
Dim L_MAXCONMSG
Dim L_APPLYTOALLFTPTEXT
Dim L_APPLYTOINHERITEDFTPTEXT
Dim L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE
Dim L_INFORMATION_ERRORMESSAGE
Dim L_FTPNOTINSTALLED_ERRORMESSAGE
'Dim L_FTPWELCOMEPAGEDISCRIPTION
L_MESSAGETASKTITLETEXT = GetLocString("GeneralSettings.dll", "40420025", "")
L_WELCOMEMSG = GetLocString("GeneralSettings.dll", "40420026", "")
L_EXITMSG = GetLocString("GeneralSettings.dll", "40420027", "")
L_MAXCONMSG = GetLocString("GeneralSettings.dll", "40420028", "")
L_APPLYTOALLFTPTEXT = GetLocString("GeneralSettings.dll", "4042002B", "")
L_APPLYTOINHERITEDFTPTEXT = GetLocString("GeneralSettings.dll", "4042002C", "")
L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE = GetLocString("GeneralSettings.dll", "C042002D", "")
L_INFORMATION_ERRORMESSAGE = GetLocString("GeneralSettings.dll", "C042000F", "")
L_FTPNOTINSTALLED_ERRORMESSAGE = GetLocString("GeneralSettings.dll", "C0420058", "")
'L_FTPWELCOMEPAGEDISCRIPTION = GetLocString("GeneralSettings.dll", "40420059", "")
'-------------------------------------------------------------------------
'END of localization content
'-------------------------------------------------------------------------
'Create property page
Dim rc
Dim page
rc=SA_CreatePage(L_MESSAGETASKTITLETEXT,"",PT_PROPERTY,page)
'Serve the page
If(rc=0) then
SA_ShowPage(Page)
End if
'-------------------------------------------------------------------------
'Function: OnInitPage()
'Description: Called to signal first time processing for this page.
' Use this method to do first time initialization tasks
'Input Variables: PageIn,EventArg
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Public Function OnInitPage(ByRef PageIn,ByRef EventArg)
InitObjects()
if FTPInstalled = false then
ServeFailurePage L_FTPNOTINSTALLED_ERRORMESSAGE ,sReturnURL
end if
SetVariablesFromSystem()
OnInitPage = True
End Function
'-------------------------------------------------------------------------
'Function: OnServePropertyPage()
'Description: Called when the page needs to be served.Use this
' method to serve content
'Input Variables: PageIn,EventArg
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Public Function OnServePropertyPage(ByRef PageIn,Byref EventArg)
Call ServeCommonJavaScript()
Call ServePage()
OnServePropertyPage = True
End Function
'-------------------------------------------------------------------------
'Function: OnPostBackPage()
'Description: Called to signal that the page has been posted-back.
'Input Variables: PageIn,EventArg
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Public Function OnPostBackPage(ByRef PageIn ,ByRef EventArg)
OnPostBackPage = True
End Function
'-------------------------------------------------------------------------
'Function: OnSubmitPage()
'Description: Called when the page has been submitted for processing.
' Use this method to process the submit request.
'Input Variables: PageIn,EventArg
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Public Function OnSubmitPage(ByRef PageIn ,ByRef EventArg)
OnSubmitPage = ServeVariablesFromForm()
End Function
'-------------------------------------------------------------------------
'Function: OnClosePage()
'Description: Called when the page is about closed.Use this method
' to perform clean-up processing
'Input Variables: PageIn,EventArg
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Public Function OnClosePage(ByRef PageIn ,ByRef EventArg)
OnClosePage = TRUE
End Function
'-------------------------------------------------------------------------
'Function: ServeCommonJavaScript
'Description: Serves in initialiging the values,setting the form
' data and validating the form values
'Input Variables: None
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Function ServeCommonJavaScript()
%>
<% End Function
'-------------------------------------------------------------------------
'Function: ServePage()
'Description: For displaying outputs HTML to the user
'Input Variables: None
'Output Variables: None
'Returns: None
'Global Variables: L_DELETE_CONFIRM_TEXT
'-------------------------------------------------------------------------
Function ServePage
%>
<%
End Function
'-------------------------------------------------------------------------
'Function name: ServeVariablesFromForm()
'Description: Serves in getting the data from Client
'Input Variables: None
'Output Variables: None
'Returns: True/False
'Global Variables: None
'-------------------------------------------------------------------------
Function ServeVariablesFromForm
'setting the form variables
F_strWelcomeMsg = Request.Form("txtWelcomeMsg")
F_strExitMsg = Request.Form("txtExitMsg")
F_strMaxConMsg = Request.Form("txtMaxConMsg")
'F_AllSites = Request.Form("optAllSites")
'set the welcome message settings
If setWelcomeMsg()then
ServeVariablesFromForm = true
else
ServeVariablesFromForm = false
end if
End Function
'-------------------------------------------------------------------------
'Function name: SetVariablesFromSystem
'Description: Serves in Getting the data from Client
'Input Variables: None
'Output Variables: None
'Returns: None
'Global Variables: None
'-------------------------------------------------------------------------
Function SetVariablesFromSystem
'Getting values from system
Err.Clear
on error Resume next
Dim objSetting
Dim count
Dim strObjPath
if FTPInstalled = true then
strObjPath = GetIISWMIProviderClassName("IIs_FtpServiceSetting") & ".Name='MSFTPSVC'"
Set objSetting =G_objService.Get(strObjPath)
if Err.number <> 0 then
SetErrMsg L_INFORMATION_ERRORMESSAGE
exit function
end if
if trim(objSetting.GreetingMessage(0)) ="" and trim(objSetting.ExitMessage)="" and trim(objSetting.MaxClientsMessage)="" then
exit function
end if
F_strWelcomeMsg = objSetting.GreetingMessage(0)
if UBound(objSetting.GreetingMessage) <> -1 then
for count=1 to ubound(objSetting.GreetingMessage)
F_strWelcomeMsg = F_strWelcomeMsg & vbNewLine & objSetting.GreetingMessage(count)
next
end if
F_strExitMsg = objSetting.ExitMessage
F_strMaxConMsg = objSetting.MaxClientsMessage
'Release the object
set objSetting = nothing
end if
End Function
'-------------------------------------------------------------------------
'Function name: InitObjects
'Description: Initialization of global variables is done
'Input Variables: None
'Returns: true/false
'--------------------------------------------------------------------------
Function InitObjects()
Err.Clear
on error resume next
' Get instances of IIS_FTPServiceSetting that are visible throughout
Set G_objService = getWMIConnection(CONST_WMI_IIS_NAMESPACE)
set G_objSites = G_objService.InstancesOf(GetIISWMIProviderClassName("IIS_FTPServiceSetting"))
if Err.number <> 0 or G_objSites.count = 0 then
FTPInstalled = false
Err.Clear
else
FTPInstalled = true
end if
end function
'------------------------------------------------------------------------------------------------------
'Function name: setWelcomeMsg
'Description: Serves in setting the messages for welcome,exit and maxcon to FTP service/sites
'Input Variables: None
'Output Variables: Boolean
'Global Variables: G_objService
' G_objSites
'------------------------------------------------------------------------------------------------------
Function setWelcomeMsg()
Err.Clear
on error resume next
'Check whether FTPService is installed
InitObjects()
if FTPInstalled = true then
if NOT SetMessageForAllSites(G_objService) then
ServeFailurePage L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE, sReturnURL
end if
end if
setWelcomeMsg = true
'Release the objects
set G_objSites = nothing
set G_objService = nothing
end function
'------------------------------------------------------------------------------------------------------
'Function name: SetMessageForAllSites
'Description: Serves in setting the messages for welcome,exit and maxcon to the all FTP sites
'Input Variables: G_objService
'Output Variables: boolean
'Returns: None
'Global Variables: G_objService
'Other function used: SetMessageForNewSites
'------------------------------------------------------------------------------------------------------
Function SetMessageForAllSites(G_objService)
Err.Clear
on error resume next
Dim objSetting
Dim inst
Dim arrProp(1)
SetMessageForAllSites = false
'Set Master FTP settings
SetMessageForNewSites G_objService
'arrProp(0) = "GreetingMessage"
arrProp(0) = "ExitMessage"
arrProp(1) = "MaxClientsMessage"
Set objSetting = getMessageForNoninheritedSites(G_objService)
for each inst in objSetting
if not SetMessages(inst) then
SA_TraceOut "Ftp_WelcomeMsg", L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE
end if
Next
SetMessageForAllSites = true
'release the object
set objSetting = nothing
End Function
'------------------------------------------------------------------------------------------------------
'Function name: SetMessageForNewSites
'Description: Serves in setting the messages for welcome,exit and maxcon to the new FTP sites
'Input Variables: G_objService
'Output Variables: boolean
'Returns: None
'Global variables: G_objService
'-------------------------------------------------------------------------------------------------------
Function SetMessageForNewSites(G_objService)
Err.Clear
on error resume next
Dim objSetting
Dim strObjPath
SetMessageForNewSites = false
strObjPath = GetIISWMIProviderClassName("IIs_FtpServiceSetting") & ".Name='MSFTPSVC'"
Set objSetting =G_objService.Get(strObjPath)
if Err.number <> 0 then
SetErrMsg L_INFORMATION_ERRORMESSAGE
exit function
end if
if not SetMessages(objSetting) then
SA_TraceOut "Ftp_WelcomeMsg", L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE
exit function
end if
SetMessageForNewSites = true
'release the object
set objSetting = nothing
End Function
'-----------------------------------------------------------------------------------------------------------
'Function name: SetMessages
'Description: Serves in setting the messages for welcome,exit and maxcon.
'Input Variables: inst
'Returns: boolean 'true if no error occurs else false
'Global variables: None
'-----------------------------------------------------------------------------------------------------------
Function SetMessages(inst)
Err.Clear
on error resume next
inst.GreetingMessage = array(F_strWelcomeMsg)
inst.ExitMessage=F_strExitMsg
inst.MaxClientsMessage=F_strMaxConMsg
inst.Put_(WBEMFLAG)
if Err.number <> 0 then
SA_TraceOut "Ftp_WelcomeMsg", L_FAIL_TO_SET_WELCOME_ERROR_MESSAGE
SetMessages = false
exit function
end if
SetMessages = true
End function
'---------------------------------------------------------------------------------
'Function name: getMessageForNoninheritedSites
'Description: gets the sites which are non inherited from master service
'Input Variables: Service
'Returns: Instances
'Global variables: None
'----------------------------------------------------------------------------------
Function getMessageForNoninheritedSites(G_objService)
Err.Clear
on error resume next
Dim strQuery
Dim objInstances
Dim objChild
Dim objMaster
Dim count
Dim strTemp
Dim instMaster
Dim instChild
Dim strWelcomeMsg
Dim strExitMsg
Dim strMaxConMsg
Dim strChildWelcomeMsg
set objMaster = G_objService.InstancesOf(GetIISWMIProviderClassName("IIs_Ftpservicesetting"))
for each instMaster in objMaster
strWelcomeMsg = instMaster.GreetingMessage(0)
for count=1 to ubound(instMaster.GreetingMessage)
strWelcomeMsg = strWelcomeMsg & vbNewLine & instMaster.GreetingMessage(count)
next
strExitMsg = instMaster.ExitMessage
strMaxConMsg = instMaster.MaxClientsMessage
next
'release the object
set objMaster = nothing
set objChild = G_objService.InstancesOf(GetIISWMIProviderClassName("IIs_FtpServerSetting"))
strQuery = "select * from " & GetIISWMIProviderClassName("IIS_FtpServerSetting") & " where "
for each instChild in objChild
strChildWelcomeMsg = instChild.GreetingMessage(0)
for count=1 to ubound(instChild.GreetingMessage)
strChildWelcomeMsg = strChildWelcomeMsg & vbNewLine & instChild.GreetingMessage(count)
next
if (strChildWelcomeMsg <> strWelcomeMsg) or (strExitMsg <> instChild.ExitMessage) or (strMaxConMsg <> instChild.MaxClientsMessage) then
strTemp = strTemp & "Name ='" & instChild.Name & "' or "
end if
next
'release the object
set objChild = nothing
strTemp = left(strTemp,len(strTemp)-3)
strQuery = strQuery & strTemp
set objInstances = G_objService.ExecQuery(strQuery)
set getMessageForNoninheritedSites = objInstances
End function
%>