AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / user-17217445

play_something_good's questions

Martin Hope
play_something_good
Asked: 2025-04-02 16:42:13 +0800 CST

Aplicativo de função - autenticação do provedor de identidade

  • 5

Estou tentando adicionar autenticação ao meu aplicativo de funções do Azure antes de permitir que solicitações sejam processadas.

Para evitar o manuseio manual da tokenização, tentei configurar o Provedor de Identidade para meu Aplicativo de Função.

O que fiz até agora: Criei um registro de aplicativo com as seguintes configurações:

Página de autenticação:

insira a descrição da imagem aqui

Permissões da API:

insira a descrição da imagem aqui

Expor uma API

insira a descrição da imagem aqui

Provedor de identidade

insira a descrição da imagem aqui

O problema: quando tento testar ou executar minha função, recebo um erro 401 Unauthorized. Eu esperava que o Identity Provider lidasse com a autenticação automaticamente. No entanto, quando clico no domínio padrão, ele não solicita autorização. Em vez disso, uma nova janela é aberta com as seguintes telas: insira a descrição da imagem aqui insira a descrição da imagem aqui

Observações adicionais:

Se eu navegar manualmente até https://func-myfunc-01.azurewebsites.net/.auth/login/aad/callback, a autenticação funciona e sou autorizado com sucesso.

Meu objetivo:

Quero que os usuários sejam solicitados a autenticar antes de acessar a URL da Função. Uma vez autenticados, eles devem conseguir executar a função.

O que estou fazendo errado? Qualquer orientação seria muito apreciada.

Obrigado!

  • 1 respostas
  • 29 Views
Martin Hope
play_something_good
Asked: 2024-12-12 23:43:48 +0800 CST

Implantação OpenIA com bicep

  • 5

Estou tentando implantar o recurso OpenAI no norte da Europa, mas recebo o erro abaixo

Detalhes da exceção: (InvalidApiSetId) O tipo de conta 'OpenAI' é inválido ou indisponível na região fornecida. Código: InvalidApiSetId Mensagem: O tipo de conta 'OpenAI' é inválido ou indisponível na região fornecida.

Não está disponível northeuropeou minha API não está funcionando? Belo é meu código que funcionou há 2 semanas para Westeuropea região

param openAIAccountName string
param location string = resourceGroup().location

param privatesubnetId string
param publicsubnetId string
param IPRules array

resource openAIAccount 'Microsoft.CognitiveServices/accounts@2024-04-01-preview' = {
  name: openAIAccountName
  location: location
  sku: {
    name: 'S0'
  }
  kind: 'OpenAI'
  properties: {
    publicNetworkAccess: 'Enabled'
    customSubDomainName: openAIAccountName
    networkAcls: {
      defaultAction: 'Deny'
      virtualNetworkRules: [
        {
          id: privatesubnetId
        }
        {
          id:publicsubnetId
        }
      ]
      ipRules: [
        for ip in IPRules: {
          value: ip
        }
      ]
    }
  }
}

resource gpt3_5 'Microsoft.CognitiveServices/accounts/deployments@2024-04-01-preview' = {
  parent: openAIAccount
  name: 'gpt35Endpoint'
  sku: {
    name: 'Standard'
    capacity: 120
  }
  properties: {
    model: {
      format: 'OpenAI'
      name: 'gpt-35-turbo'
      version: '0301'
    }
    versionUpgradeOption: 'OnceNewDefaultVersionAvailable'
    currentCapacity: 120
    raiPolicyName: 'Microsoft.Default'
  }
}
  • 1 respostas
  • 45 Views
Martin Hope
play_something_good
Asked: 2024-12-12 18:23:06 +0800 CST

arquivo yaml - parâmetro maiúsculo

  • 5

Gostaria de tornar meu parâmetro em maiúsculas

parameters:
  #Relative path to the BuildDirectory where artifacts are stored
  artifactLocation : ''
  env : ''
  serviceConnectionName: ''
  subscriptionId: ''
  #Arguments String to be used for the ADF deployment
  argumentsString: ''
  datafactoryName: ''
  resourceGroupName: ''
  location: ''

jobs:
- deployment: DeploymentJob
  displayName: 'Deploying Azure Data Factory'
  pool:
    name: $(agentPoolName)
  environment: "EMEA_${{ parameters.env.ToUpper() }}_MDP"  

Recebo este erro:

Símbolo inesperado: '('. Localizado na posição 23 dentro da expressão: parameters.env.ToUpper()

qual é a sintaxe correta?

Eu também tentei dessa forma

parameters:
  # Relative path to the BuildDirectory where artifacts are stored
  artifactLocation: ''
  env: ''
  serviceConnectionName: ''
  subscriptionId: ''
  # Arguments String to be used for the ADF deployment
  argumentsString: ''
  datafactoryName: ''
  resourceGroupName: ''
  location: ''

variables:
  env_upper: ${{ upper(parameters.env) }}

jobs:
- deployment: DeploymentJob
  displayName: 'Deploying Azure Data Factory'
  pool:
    name: $(agentPoolName)
  environment: 'EMEA_${{ variables.env_upper }}_MDP'

erro disse que não expressou variáveis

E eu também tentei desta forma:

environment: 'EMEA_${{ upper(parameters.env) }}_MDP'

isso não gerou erro, mas não colocou letras maiúsculas.

yaml
  • 1 respostas
  • 15 Views
Martin Hope
play_something_good
Asked: 2024-12-04 23:14:42 +0800 CST

API do Databricks - não é possível listar o conteúdo do espaço de trabalho

  • 5

Estou tentando listar o conteúdo sob meu usuário usando a API do databricks. Abaixo está meu código

`if (-not (Get-PackageProvider -ListAvailable -Name NuGet)) { 
    Install-PackageProvider nuget -Scope CurrentUser -Force
}
if (-not (Get-Module -ListAvailable -Name azure.databricks.cicd.tools)) { 
    Install-Module -Name azure.databricks.cicd.tools -Scope CurrentUser -Force
}

Import-Module -Name azure.databricks.cicd.tools

Function Format-BearerToken ($BearerToken) {
    Return "Bearer $BearerToken"
}

try {
    # Attempt to connect to Databricks
    Connect-Databricks -BearerToken $ADB_Token -Region $region

    # List the content of the user folder
    # Assuming the user folder is "/Users/your.username" - replace with your actual user path
    $userFolderPath = "/Users/[email protected]/"  # Replace with your actual Databricks user folder path

    # Create the body as a hashtable (note the difference in creating a hashtable)
    $body = @{
        path = $userFolderPath
    }
    # Debug: Check the Body that will be sent
    $BodyText = $body | ConvertTo-Json -Depth 10
    Write-Output "Request Body: $BodyText"


    # Test the connection by making an API call to list the workspace contents in your user folder
    $workspaceContent = Invoke-DatabricksAPI -BearerToken $ADB_Token -Region $region `
        -Method GET -API "workspace/list" -Body $BodyText

    # Output the content
    $workspaceContent
}
catch {
    Write-Error "An error occurred: $_"
}`

minha saída do parâmetro de caminho se parece com isso

Request Body: {
  "path": "/Users/[email protected]/"
}

Mas eu recebo o erro

Ocorreu um erro: Não é possível processar a transformação de argumento no parâmetro 'Body'. Não é possível converter o valor do tipo "{"path": "/Users/ [email protected] /"} "System.String" para o tipo "System.Collections.Hashtable".

Eu também tentei sem $BodyText = $body | ConvertTo-Json -Depth 10e nesse caso eu obtive oerro code 404 - 404 RESOURCE_DOES_NOT_EXIST Operation was performed on a resource that does not exist.

Meu nome de usuário está correto e tenho o arquivo test.py abaixo dele.

Tenho duas perguntas:

  1. como posso listar o conteúdo? 2)Como não consegui listar o conteúdo, acho que se a autorização foi bem-sucedida, caso contrário, primeiro eu teria obtido 401 UNAUTHORIZED The request does not have valid authentication credentials for the operation.- isso está correto?
  • 1 respostas
  • 32 Views
Martin Hope
play_something_good
Asked: 2024-11-22 02:34:50 +0800 CST

RBAC com bíceps

  • 5

Estou tentando atribuir o grupo do AD à minha conta de armazenamento como colaborador e também colaborador de dados de blob de armazenamento usando o principal do serviço que é o proprietário no subnível.

param storageAccountName string
param roleId array
param adGroup string
param principalType string = 'Group'

// reference to storage account
resource storageAccount 'Microsoft.Storage/storageAccounts@2023-01-01' existing = {
  name: storageAccountName
}

resource roleAssignment1 'Microsoft.Authorization/roleAssignments@2022-04-01' = [for roleId in roleId:  {
  name: guid(subscription().subscriptionId, resourceGroup().name, storageAccountName, roleId, adGroup)
  scope: storageAccount
  properties: {
    roleDefinitionId: subscriptionResourceId('Microsoft.Authorization/roleDefinitions', roleId)
    principalId: adGroup
    principalType: principalType
  }
}
]

Eu recebo esse erro

code":"GroupTypeNotSupported","message":"Only security-enabled groups can be used in role assignments."}
  • 1 respostas
  • 17 Views
Martin Hope
play_something_good
Asked: 2024-11-21 00:13:39 +0800 CST

Falha de autorização do aplicativo lógico - integração vnet necessária

  • 6

Estou tentando tornar meu ambiente um pouco mais seguro. Adicionei o endpoint privado para minha conta de armazenamento.

Mas agora o problema é que meu aplicativo lógico não consegue alcançar e falha

"body": {
    "message": "AuthorizationFailure\r\nclientRequestId: 7772864e-9a15-41ca-b02f-xxxxx",
    "status": 403,
    "error": {
        "message": "AuthorizationFailure"
    },
    "source": "azureblob-we.azconn-we-003.p.azurewebsites.net"
}

Lógica é algo novo para mim, então eu agradeceria sua contribuição sobre como adicionar a integração Vnet ao aplicativo lógico já existente.

Acho que as fontes que encontrei no Google estão um pouco desatualizadas porque minha interface de usuário é um pouco diferente, pois não vejo a aba "rede" em configurações no painel lateral esquerdo.

insira a descrição da imagem aqui

  • 1 respostas
  • 45 Views
Martin Hope
play_something_good
Asked: 2024-03-04 20:54:57 +0800 CST

Adicionar tags aos recursos - power shell

  • 5

Estou tentando atribuir as tags ao grupo de recursos durante a implantação. Também uso o arquivo ini onde tenho minhas variáveis ​​definidas.

Esta é a minha duas funções que lê o arquivo ini e cria o grupo Resoure

    function Get-IniContent ($filePath)
{
    $ini = @{}
    switch -regex -file $FilePath
    {
        "^\[(.+)\]" # Section
        {
            $section = $matches[1]
            $ini[$section] = @{}
            $CommentCount = 0
        }
        "^(;.*)$" # Comment
        {
            $value = $matches[1]
            $CommentCount = $CommentCount + 1
            $name = "Comment" + $CommentCount
            $ini[$section][$name] = $value
        }
        "(.+?)\s*=(.*)" # Key
        {
            $name,$value = $matches[1..2]
            $ini[$section][$name] = $value
        }
    }
    return $ini
}


function Create-ResourceGroup {
    param (
        [string] $rgName,
        [string] $saName,
        [hashtable] $tags
    )
    
    az group create --name $rgName --location "westeurope" --tags $tags


}

E eu tenho o arquivo separado onde chamo essa função conforme abaixo:

. ".\functions.ps1"

# Get variables from the INI file
$iniFilePath = "../configuration/variables.ini"
$iniContent = Get-IniContent $iniFilePath

# Get today's date
$today = Get-Date -Format yyyy-MM-dd
$trainerName = $iniContent["project"]["trainer"]
$projectName = $iniContent["project"]["name"]

$tags = @{
    "CreationDate" = $today
    "Trainer" = $trainerName
    "Project" = $projectName
}

# Iterate over the trainees section
foreach ($key in $iniContent["trainees"].Keys) {
    # Get the trainee name
    $traineeName = $iniContent["trainees"][$key]


    $names = $traineeName -split ' '
    $lastname = ($traineeName -split ' ')[1].Substring(0, [Math]::Min(5, $traineeName.IndexOf(" "))).ToLower()
    # RG name
    $resourceGroupName = "rg-academy-databricks-$lastname"
    # SA name
    $storageName = "stacademy$lastname"
    # DB name
    $databricksName = "dbs-academy-course-$lastname-001"


    # Call function to create resources

    Create-ResourceGroup -rgName $resourceGroupName -saName $storageName -tags $tags


}

o código não falha, mas as tags que defini não são passadas; em vez disso, vejo System.Collections.Hashtable: como mostra a imagem abaixo. Eu tentei respingar e substituí, --tags $tagsmas --tags @tagsocorreu o erroMissing an argument for parameter 'tags'

insira a descrição da imagem aqui

  • 1 respostas
  • 40 Views
Martin Hope
play_something_good
Asked: 2024-01-03 22:43:41 +0800 CST

Erro: Iteração sobre valor não iterável - terraform

  • 6

Sou muito novo no terraform e não entendo o que estou fazendo de errado. Meu objetivo é filtrar a lista com base na palavra específica que cada valor pode ter.

Então meu módulo fica assim onde eu defino opipeline_list

    module "pipelines" {
  source = "./pipelines"

  for_each = var.pipelines

  project_id    = data.azuredevops_project.dataanalytics.id
  repo_id       = module.repositories[each.key].repo_id
  pipeline_list = each.value
  group_ids = local.group_ids
}

pipelinesO próprio arquivo tfvars se parece com isso

    pipelines = {
  Infrastructure = [
    "pipelines/BI-Infrastructure-IaC-CI.yml",
    "pipelines/BI-Infrastructure-IaC-Deploy.yml"
  ],
  Applications = [
    "datafactory/pipelines/DataAnalytics-Datafactory-Test.yml",
    "datafactory/pipelines/DataAnalytics-Datafactory-CI.yml",
    "datafactory/pipelines/DataAnalytics-Datafactory-Deploy.yml",
    "databricks/pipelines/BI-Applications-Databricks-CI.yml",
    "databricks/pipelines/BI-Applications-Databricks-Deploy.yml"
  ]
}

E eu gostaria de filtrar esta lista e escolher apenas os valores que contêm "Implantar" nela.

Minha tentativa é assim:

locals {
  deploy_pipelines = flatten([
    for project, pipelines in var.pipeline_list : [
      for pipeline in pipelines : 
        contains(pipeline, "Deploy") ? pipeline : null
    ]
  ])
}

Mas recebo o erro dizendo isso

insira a descrição da imagem aqui

Por favor, poderia ajudar a identificar onde faço o mistkae?

EDIT: mudei os locais dessa forma, acho que estava fazendo um loop extra, já que o projeto não está lá. mas recebo um novo erro dizendo que a chamada para a função "contém" falhou: o argumento deve ser lista, tupla ou conjunto.

locals {
  deploy_pipelines = flatten([
    for pipeline in var.pipeline_list : 
        contains(pipeline, "Deploy") ? pipeline : null
    ]
  )
    }
terraform
  • 1 respostas
  • 30 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve