Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

July 7 - July 17 | Round 2 of the Power BI Dataviz World Championships. Don't miss your chance! Learn more

Reply
Leafde
New Member

Add/Remove/Update Organization Wide Sharing Links

Hello,

 

We are doing some clean up of sharing links in our environment and are investigating the possibility of seeing if we can programatically complete the process instead of doing it manually. I can grab a list of the items via the API with the "Admin - WidelySharedArtifacts LinksSharedToWholeOrganization" call however there doesn't seem to be any option to programatically add/remove/update these artifacts. I've also tried looking at the PowerShell cmdlets for Power BI however those basically seem to just be wrappers for the regular REST API. Does anybody know if there are any other ways to programatically add/remove/update organization wide sharing links or if the feature is at least being worked on by Microsoft?

 

I've tried using reviewing Developer Options in my browser and can see requests going to the below endpoint however I can't find any documentation. When I try making HTTP GET/DELETE requests etc I get 401 Unauthorized.

https://wabi-us-east2-d-primary-redirect.analysis.windows.net/metadata/links

4 REPLIES 4
Leafde
New Member

@_willie_ @Anonymous Just posting an additional update here for you both, I could not find any workarounds to do this programatically so I just did it manually.

Hi @Leafde  

Sorry to hear you had to delete each one manually. 

 

In case this helps anyone we ended putting together a few commands and ran the following

 

# Check for Power BI Module and install if not found
Write-Host "Checking for Power BI Module"
try
{
    Import-Module MicrosoftPowerBIMgmt.Profile
}
catch
{
    Install-Module -Name MicrosoftPowerBIMgmt.Profile -Force -AllowClobber
    Import-Module MicrosoftPowerBIMgmt.Profile
}
if (!(Get-Module -ListAvailable -Name MicrosoftPowerBIMgmt.Profile))
{
    throw "Module MicrosoftPowerBIMgmt.Profile not found"
}

# Enter your Power BI Service URL
# Can be found using F12 > Network > Headers > Request URL
$pbiServiceURL = "https://wabi-us-east2-redirect.analysis.windows.net"

# Connect to PowerBI Service
Write-Host "Connecting to Power BI Service"
$loginInfo = Connect-PowerBIServiceAccount
Write-Host "Logged in as $($loginInfo.UserName)"

# Set token for Power BI API
$token = (Get-PowerBIAccessToken).Authorization

# Get all workspaces
Write-Host "Getting all workspaces"
$aWorkspaces = @()
$tResults = Invoke-PowerBIRestMethod -Url 'admin/groups?$top=5000&$skip=0' -Method GET
$aWorkspaces = ($tResults | ConvertFrom-Json).value
$tResults = $null

# Traverse each workspace
foreach ($workspace in $aWorkspaces)
{

    # Grant Admin Access to Workspace
    Add-PowerBIWorkspaceUser -Id $workspace.Id -Scope Organization -UserPrincipalName $loginInfo.UserName -AccessRight Admin

    Write-Host "Sleeping for 10 seconds..."
    Start-Sleep -s 10

    $workspaceName = $workspace.Name
    Write-Host "Currently on $($workspaceName)"
    
    # get list of workspaces
    $lWorkspaceURL = "$($pbiServiceURL)/powerbi/metadata/refreshusermetadata"
    $rWorkspace = Invoke-WebRequest -Uri $lWorkspaceURL -Method PUT -Headers @{
        "Authorization" = "$token"
    }

    # get reports for the workspace
    # artfactId eq 2 is for reports
    $artifactIds = $null
    $artifactIds = (($rWorkspace.Content | ConvertFrom-Json).artifactOwnerInfo | Where-Object { $_.groupDisplayName -eq $workspaceName -and $_.artifactType -eq '2' }).artifactId

    # traverse each report
    foreach ($artifactId in $artifactIds)
    {
        
        # get report links
        $reportLinkURL = "$($pbiServiceURL)/metadata/links/report/$artifactId"
        $rLinks = Invoke-WebRequest -Uri $reportLinkURL -Method GET -Headers @{
            "Authorization" = "$token"
        } -ErrorAction Stop
        
        # convert json to object
        $links = $null
        $links = $rLinks.Content | ConvertFrom-Json

        # traverse each link
        foreach ($link in $links)
        {

            # if link is for entire org
            if ($link.entireOrg -eq $true -and $link.artifactType -eq '2')
            {

                $linkId = $link.id
                $linkURL = "$($pbiServiceURL)/metadata/links/$linkId"
                $tResult = Invoke-WebRequest -Uri $linkURL -Method DELETE -Headers @{
                    "Authorization" = "$token"
                } 

                Write-Host "`tRemoved Link for $($linkId) for $($workspaceName)"
            
            }
        }
    
    }

    # Remove Admin Access to Workspace
    Remove-PowerBIWorkspaceUser -Id $workspace.Id -Scope Organization -UserPrincipalName $loginInfo.UserName

    Write-Host ""

}

 

the script is AS IS and would suggest testing to ensure it works with the intended environment. 

 

_willie_
New Member

@Leafde,  By any chance, did you find any alternative to remove the Org Links?

Anonymous
Not applicable

Did you ever get anywhere with this? I've got about 350 such links that I'd like to remove and would prefer not to do it manually. Thanks!

Helpful resources

Announcements
FabCon and SQLCon Barcelona 2026

FabCon & SQLCon – Barcelona 2026

Join us in Barcelona for FabCon and SQLCon, the Fabric, Power BI, SQL, and AI community event. Save €200 with code FABCMTY200.

60 days of Data Days Carousel

Data Days 2026

Join Fabric Data Days 2026: 60 days of free live/on-demand sessions, challenges, study groups, and certification opportunities.

Power BI DataViz World Championships carousel

Power BI DataViz World Championships - June 2026

A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.

Top Solution Authors