Skip to content

dronkoff/pbi-report-mover

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Archive / Restor PBI Reports

Dependencies

PowerShell

Azure Functions Core Tools

Azure Functions for Visual Studio Code

PowerShell for Visual Studio Code

AdventureWorks sample databases

Description

Manully create an empty dataset with the name FakeDataset in the workspace called .

Archive

  • Rebind target report to FakeDataset
    (in order not to export data from original dataset to pbix file)
  • Export report to pbix file in temp folder
  • Upload pbix to blob storage
  • Create record with archived report information in storage table
  • Delete report from workspace

example: http://localhost:7071/api/Archive-PBIReport?WorkspaceId=[WS_ID]&ReportName=[REPORT_NAME]

Restore

  • Read the archived report information from storage table
  • Download pbix file from blob storage
  • Import pbix file to workspace
  • Rebind report to original dataset
    (name taken from archived report information)
  • Delete fake dataset that was imported with pbix file from the workspace
  • Delete record from storage table
  • Delete pbix file from blob storage

example: http://localhost:7071/api/Restore-PBIReport?WorkspaceId=[WS_ID]&ReportId=[REPORT_ID]

✔️ Works with incremental refresh enabled datasets.

Environment

  • Key Vault is used to store secrets,
  • Azure Function uses Managed Identity to access KeyVault, (locally is uses environment variables from local.settings.json)
  • App Registration is created in AAD with a secret, (secret is stored in KV or in local environment variables in local.settings.json)
  • AAD Group is created, This group is granted access to PBI workspaces. There is no way to grant access to service principal directly. Only using group. Managed Identity can’t be used because Connect-PowerBIServiceAccount command does not support MI. Azure Function code authenticates as app registration service principal using secret from KV or local storage
  • PBI Admin Portal -> Tenant Settings -> Service Princical can use Fabric APIs
    Enable, Specific Securtiy Groups -> Add AAD Group.
  • PBI Admin Portal -> Admin API Settings -> Service Princical can access read-only admin APIs
    Enable, Specific Securtiy Groups -> Add AAD Group.

Use local.settings.json to store local environment variables.

{
  "IsEncrypted": false,
  "Values": {
    "FUNCTIONS_WORKER_RUNTIME": "powershell",
    "FUNCTIONS_WORKER_RUNTIME_VERSION": "7.4",
    "AzureWebJobsStorage": "UseDevelopmentStorage=true",
    "TENANT_ID": "[...]",
    "KEY_VAULT_NAME": "[...]",
    "APP_REG_CLIENT_ID": "[...]",
    "APP_REG_CLIENT_SECRET": "[...]",
    "FAKE_DATASET_NAME": "FakeDataset",
    "STORAGE_ACCOUNT_RG": "[...]",
    "STORAGE_ACCOUNT_NAME": "[...]",
    "BLOB_CONTAINER_NAME": "pbix-archive",
    "TABLE_NAME": "pbixarchive"
  }
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published