I had a great question from Scott Forsyth earlier today about programmatically flushing the logs for an FTP site. Scott had noticed that there was a FlushLog method listed on the following page in the IIS Configuration Reference:
http://www.iis.net/ConfigReference/system.applicationHost/sites/site/ftpServer
Unfortunately there wasn't a code sample for that method; but as luck would have it, I had already written some code to do just that. (I love synchronicity...) With that in mind, I though that I'd post the code in a blog. In keeping with the cross-language samples that I wrote for the topics in the Configuration Reference, I thought that's I'd include several languages in this blog to make it easier for someone else to copy and paste.
using System;using System.Text;using Microsoft.Web.Administration;internal static class Sample{ private static void Main() { using (ServerManager serverManager = new ServerManager()) { Configuration config = serverManager.GetApplicationHostConfiguration(); // Retrieve the sites collection. ConfigurationSection sitesSection = config.GetSection("system.applicationHost/sites"); ConfigurationElementCollection sitesCollection = sitesSection.GetCollection(); // Locate a specific site. ConfigurationElement siteElement = FindElement(sitesCollection,"site","name",@"ftp.contoso.com"); if (siteElement == null) throw new InvalidOperationException("Element not found!"); // Create an object for the ftpServer element. ConfigurationElement ftpServerElement = siteElement.GetChildElement("ftpServer"); // Create an instance of the FlushLog method. ConfigurationMethodInstance FlushLog = ftpServerElement.Methods["FlushLog"].CreateInstance(); // Execute the method to flush the logs for the FTP site. FlushLog.Execute(); } } // Locate and return the index for a specific element in a collection. private static ConfigurationElement FindElement(ConfigurationElementCollection collection, string elementTagName, params string[] keyValues) { foreach (ConfigurationElement element in collection) { if (String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase)) { bool matches = true; for (int i = 0; i < keyValues.Length; i += 2) { object o = element.GetAttributeValue(keyValues[i]); string value = null; if (o != null) { value = o.ToString(); } if (!String.Equals(value, keyValues[i + 1], StringComparison.OrdinalIgnoreCase)) { matches = false; break; } } if (matches) { return element; } } } return null; }}
Imports SystemImports System.TextImports Microsoft.Web.AdministrationModule Sample Sub Main() Dim serverManager As ServerManager = New ServerManager Dim config As Configuration = serverManager.GetApplicationHostConfiguration ' Retrieve the sites collection. Dim sitesSection As ConfigurationSection = config.GetSection("system.applicationHost/sites") Dim sitesCollection As ConfigurationElementCollection = sitesSection.GetCollection ' Locate a specific site. Dim siteElement As ConfigurationElement = FindElement(sitesCollection,"site","name","ftp.contoso.com") If (siteElement Is Nothing) Then Throw New InvalidOperationException("Element not found!") End If ' Create an object for the ftpServer element. Dim ftpServerElement As ConfigurationElement = siteElement.GetChildElement("ftpServer") ' Create an instance of the FlushLog method. Dim FlushLog As ConfigurationMethodInstance = ftpServerElement.Methods("FlushLog").CreateInstance() ' Execute the method to flush the logs for the FTP site. FlushLog.Execute() End Sub ' Locate and return the index for a specific element in a collection. Private Function FindElement(ByVal collection As ConfigurationElementCollection, ByVal elementTagName As String, ByVal ParamArray keyValues() As String) As ConfigurationElement For Each element As ConfigurationElement In collection If String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase) Then Dim matches As Boolean = True Dim i As Integer For i = 0 To keyValues.Length - 1 Step 2 Dim o As Object = element.GetAttributeValue(keyValues(i)) Dim value As String = Nothing If (Not (o) Is Nothing) Then value = o.ToString End If If Not String.Equals(value, keyValues((i + 1)), StringComparison.OrdinalIgnoreCase) Then matches = False Exit For End If Next If matches Then Return element End If End If Next Return Nothing End FunctionEnd Module
// Create a Writable Admin Manager object.var adminManager = new ActiveXObject('Microsoft.ApplicationHost.WritableAdminManager');adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST";// Retrieve the sites collection.var sitesSection = adminManager.GetAdminSection("system.applicationHost/sites","MACHINE/WEBROOT/APPHOST");var sitesCollection = sitesSection.Collection;// Locate a specific site.var siteElementPos = FindElement(sitesCollection,"site",["name","ftp.contoso.com"]);if (siteElementPos == -1) throw "Element not found!";// Retrieve the site element.var siteElement = sitesCollection.Item(siteElementPos);// Create an object for the ftpServer element.var ftpServerElement = siteElement.ChildElements.Item("ftpServer");// Create an instance of the FlushLog method.var FlushLog = ftpServerElement.Methods.Item("FlushLog").CreateInstance();// Execute the method to flush the logs for the FTP site.FlushLog.Execute();// Locate and return the index for a specific element in a collection.function FindElement(collection, elementTagName, valuesToMatch) { for (var i = 0; i < collection.Count; i++) { var element = collection.Item(i); if (element.Name == elementTagName) { var matches = true; for (var iVal = 0; iVal < valuesToMatch.length; iVal += 2) { var property = element.GetPropertyByName(valuesToMatch[iVal]); var value = property.Value; if (value != null) { value = value.toString(); } if (value != valuesToMatch[iVal + 1]) { matches = false; break; } } if (matches) { return i; } } } return -1;}
' Create a Writable Admin Manager object.Set adminManager = CreateObject("Microsoft.ApplicationHost.WritableAdminManager")adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST"' Retrieve the sites collection.Set sitesSection = adminManager.GetAdminSection("system.applicationHost/sites","MACHINE/WEBROOT/APPHOST")Set sitesCollection = sitesSection.Collection' Locate a specific site.siteElementPos = FindElement(sitesCollection,"site",Array("name","ftp.contoso.com"))If siteElementPos = -1 Then WScript.Echo "Element not found!" WScript.QuitEnd If' Retrieve the site element.Set siteElement = sitesCollection.Item(siteElementPos)' Create an object for the ftpServer element.Set ftpServerElement = siteElement.ChildElements.Item("ftpServer")' Create an instance of the FlushLog method.Set FlushLog = ftpServerElement.Methods.Item("FlushLog").CreateInstance()' Execute the method to flush the logs for the FTP site.FlushLog.Execute()' Locate and return the index for a specific element in a collection.Function FindElement(collection, elementTagName, valuesToMatch) For i = 0 To CInt(collection.Count) - 1 Set element = collection.Item(i) If element.Name = elementTagName Then matches = True For iVal = 0 To UBound(valuesToMatch) Step 2 Set property = element.GetPropertyByName(valuesToMatch(iVal)) value = property.Value If Not IsNull(value) Then value = CStr(value) End If If Not value = CStr(valuesToMatch(iVal + 1)) Then matches = False Exit For End If Next If matches Then Exit For End If End If Next If matches Then FindElement = i Else FindElement = -1 End IfEnd Function
Hopefully this gives you an idea of how to call the FlushLog method. You can also use these examples to call the Start and Stop methods for FTP sites; you just need to substitute the correct method in place of the FlushLog method.