<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: HTTP 400 Bad Request calling Datasets - Update Datasources In Group REST method in Developer</title>
    <link>https://community.fabric.microsoft.com/t5/Developer/HTTP-400-Bad-Request-calling-Datasets-Update-Datasources-In/m-p/1794866#M29088</link>
    <description>&lt;P&gt;Did you have a resolution for this issue?&lt;/P&gt;</description>
    <pubDate>Tue, 20 Apr 2021 11:22:25 GMT</pubDate>
    <dc:creator>Anonymous</dc:creator>
    <dc:date>2021-04-20T11:22:25Z</dc:date>
    <item>
      <title>HTTP 400 Bad Request calling Datasets - Update Datasources In Group REST method</title>
      <link>https://community.fabric.microsoft.com/t5/Developer/HTTP-400-Bad-Request-calling-Datasets-Update-Datasources-In/m-p/514123#M15867</link>
      <description>&lt;P&gt;I am writing a script that users can run to update all their DNS based analysis services connections to the new link:// alias style connection. The whole script is below:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;#Requires -Version 5
Set-StrictMode -Version Latest

Install-Module -Name MicrosoftPowerBIMgmt -Scope CurrentUser
Import-Module MicrosoftPowerBIMgmt
Connect-PowerBIServiceAccount

try {
    $groups = Invoke-PowerBiRestMethod -Url 'https://api.powerbi.com/v1.0/myorg/groups/' -Method GET | ConvertFrom-Json

    foreach ($group in $groups.value) {
        Write-Host "Processing group $($group.name)"
        $groupId = $group.id
        $dataSets = Invoke-PowerBiRestMethod -Url "https://api.powerbi.com/v1.0/myorg/groups/$groupId/datasets" -Method GET | ConvertFrom-Json

        foreach ($dataset in $datasets.value) {
            Write-Host "Processing dataset $($dataset.name)"
            $dataSetId = $dataset.id

            $dataSourceUri = "https://api.powerbi.com/v1.0/myorg/groups/$groupId/datasets/$dataSetId/datasources"
            $dataSources = Invoke-PowerBiRestMethod -Url $dataSourceUri -Method GET | ConvertFrom-Json

            if (-not $dataSources) {
                Resolve-PowerBIError -Last
                continue
            }

            $updates = $dataSources.value |
                Where-Object { $_.datasourceType -eq 'AnalysisServices' } |
                Where-Object { $_.connectionDetails.server -match 'cube\.ds-\w*\.foobar\.com' } |
                ForEach-Object {
                    $update = [pscustomobject] [ordered] @{
                        datasourceSelector = [pscustomobject] [ordered] @{
                            datasourceType = $_.datasourceType
                            connectionDetails = $_.connectionDetails
                        }
                        connectionDetails = [pscustomobject] [ordered] @{
                            server = "link://wibble.foobar.com"
                            database = $_.connectionDetails.database
                        }
                    }

                    Write-Output $update
                }

            if ($null -eq $updates)
            {
                continue
            }

            Write-Host "Found analysis services connections"

            $updateDetails = @{
                updateDetails = $updates
            }

            Write-Host "Updating connection details" -ForegroundColor Cyan

            $body = $updateDetails | ConvertTo-Json -Depth 10
            $url = "https://api.powerbi.com/v1.0/myorg/groups/$groupId/datasets/$dataSetId/Default.UpdateDatasources"
            $updateResponse = Invoke-PowerBiRestMethod -Url $url -Method POST -Body $body -ErrorAction Stop | ConvertFrom-Json

            Write-Output $updateResponse
        }
    }
}
catch {
    Resolve-PowerBIError -Last
}&lt;/PRE&gt;&lt;P&gt;The final post body looks fine according to the docs but I get a Bad Request response from the service.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;With no additional clues I have no idea what to try next.&lt;/P&gt;</description>
      <pubDate>Wed, 12 Sep 2018 17:24:47 GMT</pubDate>
      <guid>https://community.fabric.microsoft.com/t5/Developer/HTTP-400-Bad-Request-calling-Datasets-Update-Datasources-In/m-p/514123#M15867</guid>
      <dc:creator>jsnape</dc:creator>
      <dc:date>2018-09-12T17:24:47Z</dc:date>
    </item>
    <item>
      <title>Re: HTTP 400 Bad Request calling Datasets - Update Datasources In Group REST method</title>
      <link>https://community.fabric.microsoft.com/t5/Developer/HTTP-400-Bad-Request-calling-Datasets-Update-Datasources-In/m-p/1794866#M29088</link>
      <description>&lt;P&gt;Did you have a resolution for this issue?&lt;/P&gt;</description>
      <pubDate>Tue, 20 Apr 2021 11:22:25 GMT</pubDate>
      <guid>https://community.fabric.microsoft.com/t5/Developer/HTTP-400-Bad-Request-calling-Datasets-Update-Datasources-In/m-p/1794866#M29088</guid>
      <dc:creator>Anonymous</dc:creator>
      <dc:date>2021-04-20T11:22:25Z</dc:date>
    </item>
  </channel>
</rss>

