PoshCode Archive  Artifact [46d8422561]

Artifact 46d8422561596fa7ba4a4442c6c3cb45ce7c0eaf7f38c64a93d9ce1a623be0cb:

  • File Manage-ASP-NET-Providers.ps1 — part of check-in [17b23bd9e5] at 2018-06-10 12:59:54 on branch trunk — Manage ASP.NET MemberShip, Role and Profile Provider with PowerShell. Especially useful with SqlMembershipProvider. I use it to manage SharePoint users with form based authentication (FBA). (user: cglessner size: 3471)

# encoding: ascii
# api: powershell
# title: Manage ASP.NET Providers
# description: Manage ASP.NET MemberShip, Role and Profile Provider with PowerShell. Especially useful with SqlMembershipProvider. I use it to manage SharePoint users with form based authentication (FBA).
# version: 0.1
# type: function
# author: cglessner
# license: CC0
# x-poshcode-id: 1674
# x-archived: 2010-03-09T09:40:31
#
#
# Manage_ASP_NET_Providers.ps1
# by Chistian Glessner
# http://iLoveSharePoint.com

# If you want to change the app config you have to restart PowerShell
param($appConfigPath=$null)

# App config path have to be set before loading System.Web.dll
[System.AppDomain]::CurrentDomain.SetData("APP_CONFIG_FILE", $appConfigPath )
[void][System.Reflection.Assembly]::LoadWithPartialName("System.Web") 

function global:Get-MembershipProvider($providerName=$null, [switch]$all)
{    
	if($all)
	{
		return [System.Web.Security.Membership]::Providers
	}
	
    if($providerName -eq $null)
    {
        return [System.Web.Security.Membership]::Provider
    }
    else
    {
        return [System.Web.Security.Membership]::Providers[$providerName]
    } 
}

function global:Add-MembershipUser($login=$(throw "-login is required"), $password=$(throw "$password is required"), $mail=$(throw "-mail is required"),$question, $answer, $approved=$true)
{
	$provider = $input | select -First 1
	
	if($provider -isnot [System.Web.Security.MembershipProvider])
	{
		$provider = Get-MembershipProvider
	}

	$status = 0
	$provider.CreateUser($login, $password, $mail, $question, $answer, $approved, $null, [ref]$status)
	return [System.Web.Security.MembershipCreateStatus]$status			
}

function global:Get-MembershipUser($identifier, $maxResult=100)
{
	$provider = $input | select -First 1

	if($provider -isnot [System.Web.Security.MembershipProvider])
	{
		$provider = Get-MembershipProvider
	}
			
	if($identifier -ne $null)
	{		
		$name = $provider.GetUserNameByEmail($identifier)
		
		if($name -ne $null){$identifier = $name}		
		
		return $provider.GetUser($identifier,$false)
	}

	$totalUsers = 0
	$users = $provider.GetAllUsers(0,$maxResult,[ref]$totalUsers) 
	
	$users
	
	if($totalUsers -gt $maxResult)
	{
		throw "-maxResult limit exceeded"
	}			
}

function global:Reset-MembershipUserPassword($identifier=$(throw "-identifier is required"), $questionAnswer)
{
	$provider = $input | select -First 1

	if($provider -isnot [System.Web.Security.MembershipProvider])
	{
		$provider = Get-MembershipProvider
	}
	
	$name = $provider.GetUserNameByEmail($identifier)
		
	if($name -ne $null){$identifier = $name}	
	
	return $provider.ResetPassword($identifier, $questionAnswer)
}

function global:Get-RoleProvider($providerName=$null, [switch]$all)
{     
	if($all)
	{
		return [System.Web.Security.Roles]::Providers
	}

    if($providerName -eq $null)
    {
        return [System.Web.Security.Roles]::Provider
    }
    else
    {
        return [System.Web.Security.Roles]::Providers[$providerName]
    } 
}

function global:Get-ProfileProvider($providerName=$null)
{     
	if($all)
	{
		return [System.Web.Security.ProfileManager]::Providers
	}

    if($providerName -eq $null)
    {
        return [System.Web.Profile.ProfileManager]::Provider
    }
    else
    {
        return [System.Web.Profile.ProfileManager]::Providers[$providerName]
    } 
}