The utility required is "LDIFDE" and the syntax and explanation can be found at:
http://support.microsoft.com/kb/237677
The upshot is the statement:
ldifde -f exportOu.ldf -s Server1 -d
"dc=Export,dc=com" -p subtree -r "(objectCategory=organizationalUnit)"
-l "cn,objectclass,ou"
Where 1) "exportOU.ldf" is the file you're outputting to; 2) "Server1" is a dc in the domain; 3) "dc=Export,dc=com" is the root of the area in the namespace you want to dump; 4) "subtree" is your search scope; 5) "(object...Unit)" is the search term; and 6) "cn ...ou" is the list of attributes in the search.
When you get it, you turn it around and import it with:
ldifde -i -f exportOu.ldf -s Server2
Where 1) "exportOu.ldf" is the file you output earlier; and 2) "Server" is a DC in the domain where you want to build the OU structure.
Way easier than writing it oneself.
Saturday, May 11, 2013
Wednesday, March 27, 2013
How to determine which NT groups I am in
So useful for debugging security problems but so forgettable ...
The easy one:
whoami /groups
The really detailed one:
gpresult /V
The easy one:
whoami /groups
The really detailed one:
gpresult /V
Friday, March 15, 2013
Visual Studio error: "Unable to delete folder . This function is not supported on this system."
This is a problem I've had when using VS2010 and am trying to get rid of service references so I can re-add them.
It seems like a rights issue: The answer is to go to the folder in question using Explorer and delete it manually, then go back into VS2010 and delete it.
It seems like a rights issue: The answer is to go to the folder in question using Explorer and delete it manually, then go back into VS2010 and delete it.
Saturday, March 2, 2013
WCF error: "Custom tool warning: Cannot import wsdl.portType"
An error that comes up when moving code which calls a WCF service from development to production:
"Custom tool warning: Cannot import wsdl:portType"
It also details a number of "custom tool" errors.
The problem stems from when I pull some Visual Studio Solution code over from my development lab, delete the service references in the projects in the solution (which point to the WCF service in the devlab) and re-add them as service references pointing to the WCF service in the production lab.
Evidently a lot is going on during the creation of these service references -- when Googling for information on it other users recommend completely shutting down and restarting Visual Studio; the best recommendation comes from stackoverflow and recommends re-adding these references while specifying not to reuse types in reference assemblies:
http://stackoverflow.com/questions/1872865/what-does-this-wcf-error-mean-custom-tool-warning-cannot-import-wsdlporttype
http://www.lukepuplett.com/2010/07/note-to-self-don-let-wcf-svcutil-reuse.html
"Custom tool warning: Cannot import wsdl:portType"
It also details a number of "custom tool" errors.
The problem stems from when I pull some Visual Studio Solution code over from my development lab, delete the service references in the projects in the solution (which point to the WCF service in the devlab) and re-add them as service references pointing to the WCF service in the production lab.
Evidently a lot is going on during the creation of these service references -- when Googling for information on it other users recommend completely shutting down and restarting Visual Studio; the best recommendation comes from stackoverflow and recommends re-adding these references while specifying not to reuse types in reference assemblies:
http://stackoverflow.com/questions/1872865/what-does-this-wcf-error-mean-custom-tool-warning-cannot-import-wsdlporttype
http://www.lukepuplett.com/2010/07/note-to-self-don-let-wcf-svcutil-reuse.html
Thursday, February 28, 2013
"The maximum message size quota for incoming messages (65536) has been exceeded. To increase the quota, use the MaxReceivedMessageSize property on the appropriate binding element."
This happened when I was sending large chunks of data through a WCF service -- by default it seems that the service is configured not accept anything over a certain size, probably as a security measure.
Overriding it is done by adding a "readerQuotas" section:
<bindings>
<basicHttpBinding>
<binding maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647">
<readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
</binding>
</basicHttpBinding>
</bindings>
Drawn from this blog:
http://www.megustaulises.com/2012/04/wcf-common-error-messages-tips-and.html?_escaped_fragment_="
A word of caution, though -- in most examples I found in Google there was an admonition to add a "name" attribute to the "binding" element (e.g., http://stackoverflow.com/questions/3068076/wcf-service-the-maximum-array-length-quota-16384-has-been-exceeded) and if you use the "Edit WCF Configuration" utility in Visual Studio 2010 it'll actually say there's an error when it senses that the "name" attribute is missing.
This has confused more people than just me -- see https://go4answers.webhost4life.com/Example/maximum-array-length-quota-16384-36456.aspx, especially "Answer 6". It seems that if the "name" attribute is left out then the change is made to the global binding definition if the WCF project is .NET 4.0+.
The confusion would seem to come from an improvement in the structure of WCF config files introduced in .NET 4.0/4.5 as a "simplification" feature, documented in http://msdn.microsoft.com/en-us/library/hh309266.aspx
Overriding it is done by adding a "readerQuotas" section:
<bindings>
<basicHttpBinding>
<binding maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647">
<readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
</binding>
</basicHttpBinding>
</bindings>
Drawn from this blog:
http://www.megustaulises.com/2012/04/wcf-common-error-messages-tips-and.html?_escaped_fragment_="
A word of caution, though -- in most examples I found in Google there was an admonition to add a "name" attribute to the "binding" element (e.g., http://stackoverflow.com/questions/3068076/wcf-service-the-maximum-array-length-quota-16384-has-been-exceeded) and if you use the "Edit WCF Configuration" utility in Visual Studio 2010 it'll actually say there's an error when it senses that the "name" attribute is missing.
This has confused more people than just me -- see https://go4answers.webhost4life.com/Example/maximum-array-length-quota-16384-36456.aspx, especially "Answer 6". It seems that if the "name" attribute is left out then the change is made to the global binding definition if the WCF project is .NET 4.0+.
The confusion would seem to come from an improvement in the structure of WCF config files introduced in .NET 4.0/4.5 as a "simplification" feature, documented in http://msdn.microsoft.com/en-us/library/hh309266.aspx
Tuesday, February 26, 2013
WCF Error: "This collection already contains an address with scheme http"
This comes when pushing a new WCF service up from development to production -- it'll work fine in dev, then fail with this message in production:
"This collection already contains an address with scheme http"
The solution is to update the web.config section of the IIS hosted WCF service and the app.config section of the library used by WCF and is described in a couple different links:
I wish I knew WCF well enough to say what the fix is actually doing but at present I can't quite say what's going on -- I'm still learning it and, once I find out what my problem is, I'll add to this post. In the meantime, I've just got to get this running.
"This collection already contains an address with scheme http"
The solution is to update the web.config section of the IIS hosted WCF service and the app.config section of the library used by WCF and is described in a couple different links:
In my case, I put this code right after the <servicemodel> tag:
<servicemodel>
<serviceHostingEnvironment>
<baseAddressPrefixFilters>
 <add prefix=http://mignysm95bakpv.nysemail.nyenet"/>
<baseAddressPrefixFilters>
</serviceHostingEnvironment>
....
etc. etc. etc. ....
</servicemodel>
<servicemodel>
<serviceHostingEnvironment>
<baseAddressPrefixFilters>
 <add prefix=http://mignysm95bakpv.nysemail.nyenet"/>
<baseAddressPrefixFilters>
</serviceHostingEnvironment>
....
etc. etc. etc. ....
</servicemodel>
I wish I knew WCF well enough to say what the fix is actually doing but at present I can't quite say what's going on -- I'm still learning it and, once I find out what my problem is, I'll add to this post. In the meantime, I've just got to get this running.
Tuesday, January 15, 2013
"Could not find endpoint element with name ..." WCF error
I developed a windows service which periodically polls a WCF server for information -- I added a service reference to the project which provided a proxy for a "ProvisioningClient" object. The could would instantiate this object and then perform tasks:
using (ProvisioningClient client = new ProvisioningClient("basic")
{
// Do stuff
}
The way I create windows services is to first create a DLL that performs all of the work and then load and call it from a C# windows project.
For debugging, though, I put together a simple Windows form test harness (just a single form in a project called "Service Impersonator") with a single "Start DLL" button which loads the DLL and lets me interactively debug the DLL code.
The program would consistently fail on the "using" statement above, though, with a message:
Could not find endpoint element with the name 'basic' and contract 'ExchangeProvisioningServiceReference.IExchangeProvisioning' in the ServiceModel client configuration section...
I'd check the APP.CONFIG file in the DLL and there was indeed an endpoint element called 'basic' following that very contract; reviewing the WEB.CONFIG file of the WCF service showed that the syntax matched perfectly.
Since the code failed in the DLL and the error pointed to the APP.CONFIG file, that's where I kept looking and puzzling. The problem was not there but in the Winform test harness project: it was a very simple project which just called the DLL but for some reason the DLL looked for an APP.CONFIG file in the .EXE file calling it and, not finding one, gave me that message.
Adding a service reference to the Winform test harness project that called the DLL resolved the problem. I don't understand why the DLL doesn't look at its own APP.CONFIG file but that's the way it is.
using (ProvisioningClient client = new ProvisioningClient("basic")
{
// Do stuff
}
The way I create windows services is to first create a DLL that performs all of the work and then load and call it from a C# windows project.
For debugging, though, I put together a simple Windows form test harness (just a single form in a project called "Service Impersonator") with a single "Start DLL" button which loads the DLL and lets me interactively debug the DLL code.
The program would consistently fail on the "using" statement above, though, with a message:
Could not find endpoint element with the name 'basic' and contract 'ExchangeProvisioningServiceReference.IExchangeProvisioning' in the ServiceModel client configuration section...
I'd check the APP.CONFIG file in the DLL and there was indeed an endpoint element called 'basic' following that very contract; reviewing the WEB.CONFIG file of the WCF service showed that the syntax matched perfectly.
Since the code failed in the DLL and the error pointed to the APP.CONFIG file, that's where I kept looking and puzzling. The problem was not there but in the Winform test harness project: it was a very simple project which just called the DLL but for some reason the DLL looked for an APP.CONFIG file in the .EXE file calling it and, not finding one, gave me that message.
Adding a service reference to the Winform test harness project that called the DLL resolved the problem. I don't understand why the DLL doesn't look at its own APP.CONFIG file but that's the way it is.
Oddity when working with event logs
During development I often create then delete custom Windows event logs for my applications.
A problem arises when I do something like delete and then recreate an event log and event source in order to correct a spelling or something like that ... I'm able to delete the old log and the source but when I recreate the new (correctly spelled) log and source I will see the new log appears but I can't seem to write to it anymore.
There's a peculiarity with Windows event logs -- if you delete them and then recreate them, you need to reboot the computer for writing to the event log to begin behaving correctly again. See:
http://stackoverflow.com/questions/1901312/eventlog-createeventsource-is-not-creating-a-custom-log
and
http://msdn.microsoft.com/en-us/library/2awhba7a.aspx (about half way down the page)
A problem arises when I do something like delete and then recreate an event log and event source in order to correct a spelling or something like that ... I'm able to delete the old log and the source but when I recreate the new (correctly spelled) log and source I will see the new log appears but I can't seem to write to it anymore.
There's a peculiarity with Windows event logs -- if you delete them and then recreate them, you need to reboot the computer for writing to the event log to begin behaving correctly again. See:
http://stackoverflow.com/questions/1901312/eventlog-createeventsource-is-not-creating-a-custom-log
and
http://msdn.microsoft.com/en-us/library/2awhba7a.aspx (about half way down the page)
Sunday, January 13, 2013
Exchange 2007 Admin in C# on W2008R2 using Visual Studio 2010
I wrote a service which performed Exchange 2007 administration tasks which performed successfully for years running on a Windows 2003 R2 server. Recently we went through an upgrade to W2008R2 and Exchange 2010 and I began upgrading the service to use the new and very different PowerShell snap-in for Exchange 2010.
Suddenly we partially reversed course, however, and decided to stay with Exchange 2007 while continuing the upgrade to W2008R2 for the server OS.
So I am having to rewrite my original windows service code to run on 64-bit W2008R2 machines. I remembered that when I initially wrote the service I had several issues getting Visual Studio (then VS2005, now VS2010), the PowerShell runspace, the Exchange 2007 Administration PSSnapin, and the bit-iness of the machine to agree and to let me do what I needed to do. I remembered that these problems took days to resolve.
I would run into persistent problems getting my C# code to recognize the snap-in, to use the correct version of the System.Management.Automation tools, etc. which would be evidenced with errors like:
"No snap-ins have been registered for Windows PowerShell version 2"
"Could not load file or assembly 'Microsoft.Exchange.PowerShell.Configuration, Version=14.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35' or one of its dependencies. The system cannot find the file specified."
"MSCorlib.dll is compiled for wrong processor"
Googling around it is clear that this is a common problem and is a bit-iness issue between all the different entities and all of them must be lined up in the right way to make things work.
I established a set of steps that worked for me in a virgin test environment on a virtual machine; I then took it into my production environment (which had suffered installs and uninstalls of the Exchange 2007 and 2010 management tools) and tried it again and it worked.
The steps I followed to get it to work were:
01) Install the Exchange 2007 management tools from the Exchange 2007 SP1 distribution DVD onto the server
02) Update the management tools to service pack 3 (by downloading the Exchange 2007 SP3 download from Microsoft)
03) Start Visual Studio 2010 and create a console application.
04) Create a class in the console app to hold the Exchange 2007 Admin PowerShell wrapper written by Nick Smith (at http://knicksmith.blogspot.com/2007/03/managing-exchange-2007-recipients-with.html)
05) Have the main() method of the program.cs file call Nick Smith's exchange wrapper, e.g.:
static void main(string[] args)
{
// Do a simple dump of mailbox names
ExchangeManagementShellWrapper ems = ExchangeManagementShellWrapper.Instance;
ICollection results;
results = ems.Runsp
aceInvoke("Get-Mailbox");
foreach (PSObject item in results)
{
Console.WriteLine(item.Members["Name"].Value.ToString());
}
}
06) Make sure the project's set to build using .NET framework 3.5.
07) Make sure the project's set to build to the x64 platform
08) Make sure there's a reference to "C:\Windows\Microsoft.NET\Framework\v2.0.50727\System.Management.dll"
09) Make sure there's a reference to "C:\Program Files (x86)\Reference Assemblies\Microsoft\WindowsPowerShell\v1.0\System.Management.Automation.dll"
That should do it. The Exchange 2007 PowerShell cmdlets are only installed as x64 and the System Automation dlls only seemed to work for me if the code is targeted towards .NET 3.5, not .NET 4.0 (which my VS editor defaulted to).
I'll include the source code for the project if there's any interest in that.
Suddenly we partially reversed course, however, and decided to stay with Exchange 2007 while continuing the upgrade to W2008R2 for the server OS.
So I am having to rewrite my original windows service code to run on 64-bit W2008R2 machines. I remembered that when I initially wrote the service I had several issues getting Visual Studio (then VS2005, now VS2010), the PowerShell runspace, the Exchange 2007 Administration PSSnapin, and the bit-iness of the machine to agree and to let me do what I needed to do. I remembered that these problems took days to resolve.
I would run into persistent problems getting my C# code to recognize the snap-in, to use the correct version of the System.Management.Automation tools, etc. which would be evidenced with errors like:
"No snap-ins have been registered for Windows PowerShell version 2"
"Could not load file or assembly 'Microsoft.Exchange.PowerShell.Configuration, Version=14.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35' or one of its dependencies. The system cannot find the file specified."
"MSCorlib.dll is compiled for wrong processor"
Googling around it is clear that this is a common problem and is a bit-iness issue between all the different entities and all of them must be lined up in the right way to make things work.
I established a set of steps that worked for me in a virgin test environment on a virtual machine; I then took it into my production environment (which had suffered installs and uninstalls of the Exchange 2007 and 2010 management tools) and tried it again and it worked.
The steps I followed to get it to work were:
01) Install the Exchange 2007 management tools from the Exchange 2007 SP1 distribution DVD onto the server
02) Update the management tools to service pack 3 (by downloading the Exchange 2007 SP3 download from Microsoft)
03) Start Visual Studio 2010 and create a console application.
04) Create a class in the console app to hold the Exchange 2007 Admin PowerShell wrapper written by Nick Smith (at http://knicksmith.blogspot.com/2007/03/managing-exchange-2007-recipients-with.html)
05) Have the main() method of the program.cs file call Nick Smith's exchange wrapper, e.g.:
static void main(string[] args)
{
// Do a simple dump of mailbox names
ExchangeManagementShellWrapper ems = ExchangeManagementShellWrapper.Instance;
ICollection
results = ems.Runsp
aceInvoke("Get-Mailbox");
foreach (PSObject item in results)
{
Console.WriteLine(item.Members["Name"].Value.ToString());
}
}
06) Make sure the project's set to build using .NET framework 3.5.
07) Make sure the project's set to build to the x64 platform
08) Make sure there's a reference to "C:\Windows\Microsoft.NET\Framework\v2.0.50727\System.Management.dll"
09) Make sure there's a reference to "C:\Program Files (x86)\Reference Assemblies\Microsoft\WindowsPowerShell\v1.0\System.Management.Automation.dll"
That should do it. The Exchange 2007 PowerShell cmdlets are only installed as x64 and the System Automation dlls only seemed to work for me if the code is targeted towards .NET 3.5, not .NET 4.0 (which my VS editor defaulted to).
I'll include the source code for the project if there's any interest in that.
Subscribe to:
Posts (Atom)