summaryrefslogtreecommitdiffstats
path: root/src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs
diff options
context:
space:
mode:
authorAndrew Arnott <andrewarnott@gmail.com>2010-01-18 20:10:18 -0800
committerAndrew Arnott <andrewarnott@gmail.com>2010-01-18 20:10:18 -0800
commit47ba4e9c49be9479b7c3d30613cab982ecda042d (patch)
tree07a2a747a70e13d80aedd41294a0a3e94f60b192 /src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs
parent1f79fcb88004d86372b7392f51b914af826f1b9d (diff)
parentcdb850c6cf90381e6db75365272b7d65ef5fe359 (diff)
downloadDotNetOpenAuth-47ba4e9c49be9479b7c3d30613cab982ecda042d.zip
DotNetOpenAuth-47ba4e9c49be9479b7c3d30613cab982ecda042d.tar.gz
DotNetOpenAuth-47ba4e9c49be9479b7c3d30613cab982ecda042d.tar.bz2
Merge branch 'master' into simpleauth
Conflicts: src/DotNetOpenAuth.vsmdi src/DotNetOpenAuth/DotNetOpenAuth.csproj
Diffstat (limited to 'src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs')
-rw-r--r--src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs b/src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs
new file mode 100644
index 0000000..9cfd35d
--- /dev/null
+++ b/src/DotNetOpenAuth.BuildTasks/CheckAdminRights.cs
@@ -0,0 +1,30 @@
+//-----------------------------------------------------------------------
+// <copyright file="CheckAdminRights.cs" company="Andrew Arnott">
+// Copyright (c) Andrew Arnott. All rights reserved.
+// </copyright>
+//-----------------------------------------------------------------------
+
+namespace DotNetOpenAuth.BuildTasks {
+ using System.Security.Principal;
+ using Microsoft.Build.Framework;
+ using Microsoft.Build.Utilities;
+
+ public class CheckAdminRights : Task {
+ /// <summary>
+ /// Gets or sets a value indicating whether this process has elevated permissions.
+ /// </summary>
+ [Output]
+ public bool IsElevated { get; set; }
+
+ /// <summary>
+ /// Executes this instance.
+ /// </summary>
+ public override bool Execute() {
+ WindowsIdentity id = WindowsIdentity.GetCurrent();
+ WindowsPrincipal p = new WindowsPrincipal(id);
+ this.IsElevated = p.IsInRole(WindowsBuiltInRole.Administrator);
+
+ return true;
+ }
+ }
+}