Я полагаю, что вы можете просто установить CurrentPrincipal
в качестве первой операции кода потока после запуска потока и только после этого начинать выполнять код, который должен выполняться с другим принципалом .
Это должно позаботиться о любых проверках на основе ролей .NET. Если вам также требуется олицетворение для вызовов в ОС, вы можете выдать себя за WindowsIdentity
.
Код (может или не может работать - не проверял):
public void Run(object principalObj) {
if (principalObj == null) {
throw new ArgumentNullException("principalObj");
}
IPrincipal principal = (IPrincipal)principalObj;
Thread.CurrentPrincipal = principal;
WindowsIdentity identity = principal.Identity as WindowsIdentity;
WindowsImpersonationContext impersonationContext = null;
if (identity != null) {
impersonationContext = identity.Impersonate();
}
try {
// your code here
} finally {
if (impersonationContext != null) {
impersonationContext.Undo();
}
}
}
...
Thread thread = new Thread(Run);
thread.Start(yourPrincipal);