Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Notification Hub Namespace update failed with BadArgument Exception #2222

Open
ChrWeinert opened this issue Jul 8, 2024 · 6 comments
Open
Assignees

Comments

@ChrWeinert
Copy link

Bicep CLI version 0.28.1

We have a notification hub namespace that includes one notification hub.
During the replacement of the Google fcm message support we wanted to set the new FCM v1 settings through our bicep script.
Because these settings are only available in the "2023-10-01-preview" version, we updates our script to this version.

When running the deployment we get the following error

{
  "status": "Failed",
  "error": {
    "code": "BadArgument",
    "message": "Value cannot be null. (Parameter 'value')",
    "target": "value"
  }
}

Because we can´t get more detail information about this error, we made some tests within an empty resource group.
We created a new notification hub namespace with a notification hub and the FCM v1 setttings. Everything works fine.

grafik

When we re-run the bicep we always get the same error.
grafik

When we delete the notification hub namespace and re-run the script, everythings is working again.

It seems, there might be an issue when the deployment tries to update an existing notification hub namespace.
We tried this with the API Version "2023-09-01", but the error also happens here.

Maybe someone can help us to figure out what is going wrong and how we can update our existing notification hub (namespaces) without getting this error.

Best Regards
Christian


Here is the bicep script we use to reproduce the issue:

resource notificationHubNamespace 'Microsoft.NotificationHubs/namespaces@2023-10-01-preview' = {
  name: 'ntfns-mynotificationhubnamespace'
  location: resourceGroup().location
  sku: {
    name: 'Free'
  }
  properties: {
    namespaceType: 'NotificationHub'    
  }

  resource RootManageSharedAccessKeyAuthorizationRule 'AuthorizationRules' = {
    name: 'RootManageSharedAccessKey'
    properties: {
      rights: [
        'Listen'
        'Manage'
        'Send'
      ]
    }
  }

  resource notificationHub 'notificationHubs@2023-10-01-preview' = {
    name: 'ntf-myNotificationHub'
    location: resourceGroup().location
    
    resource DefaultFullSharedAccessSignatureAuthorizationRule 'AuthorizationRules' = {
      name: 'DefaultFullSharedAccessSignature'
      properties: {
        rights: [
          'Listen'
          'Manage'
          'Send'
        ]
      }
    }

    resource DefaultListenSharedAccessSignatureAuthorizationRule 'AuthorizationRules' = {
      name: 'DefaultListenSharedAccessSignature'
      properties: {
        rights: [
          'Listen'
        ]
      }
    }

    resource DefaultManageSendListenSharedAccessSignatureAuthorizationRule 'AuthorizationRules' = {
      name: 'DefaultManageSendListenSharedAccessSignature'
      properties: {
        rights: [
          'Listen'
          'Manage'
          'Send'
        ]
      }
    }

    resource DefaultSendListenSharedAccessSignatureAuthorizationRule 'AuthorizationRules' = {
      name: 'DefaultSendListenSharedAccessSignature'
      properties: {
        rights: [
          'Listen'
          'Send'
        ]
      }
    }

    resource DefaultSendSharedAccessSignatureAuthorizationRule 'AuthorizationRules' = {
      name: 'DefaultSendSharedAccessSignature'
      properties: {
        rights: [
          'Send'
        ]
      }
    }
  }
}
@MrBear141
Copy link

MrBear141 commented Jul 10, 2024

I have the exact same error. This script can not be run second time:

param namespaceName string = 'namespace1'
param hubName string = 'hub1'
param location string = resourceGroup().location

resource namespaceHub 'Microsoft.NotificationHubs/namespaces@2023-09-01' = {
  name: namespaceName
  location: location
  sku: {
    name: 'Free'
  }
  properties: {
    replicationRegion: 'None'
    zoneRedundancy: 'Disabled'
  }
}

resource notificationHub 'Microsoft.NotificationHubs/namespaces/notificationHubs@2023-09-01' = {
  name: hubName
  location: location
  parent: namespaceHub
}

@notaturkey
Copy link

bump

@stephaniezyen stephaniezyen self-assigned this Jul 10, 2024
@stephaniezyen
Copy link
Contributor

Unfortunately this is an RP error, please open a support ticket with the Microsoft.NotificationHubs RP team to get this issue fixed as soon as possible. We will try to route it on our end as well.

@MrBear141
Copy link

Well, here: Azure/arm-deploy#235 , the issue is complitely ignored. And that is weird, as the issue seems critical. Part of our project that responsible for sendign push notifications are completely blocked, as we can not add creating azure notification as out IaC flow. is there any options how we can draw more attention to this issue? write/call to tech support or what?

@alex-frankel
Copy link
Collaborator

alex-frankel commented Aug 21, 2024

arm-deploy is a generic GH action for deploying any bicep/ARM templates. It's not the right place to get support for a specific resource type issue like the one you are experiencing. The best next step is to open a support ticket so this can be routed to the NotificationHubs team.

I have also shared this GH thread with the NotificationHubs Product Managers to see if they can expedite the process.

@bvegso
Copy link

bvegso commented Aug 27, 2024

i was recommended to revert the apiVersion for the namespace to 2017-04-01 and keep the rest at 2023-10-01-preview. it seems to re-deploy fine like that

 "resources": [
     {
       "type": "Microsoft.NotificationHubs/namespaces",
-      "apiVersion": "2023-10-01-preview",
+      "apiVersion": "2017-04-01",

while:

    {
      "type": "Microsoft.NotificationHubs/namespaces/notificationHubs",
      "apiVersion": "2023-10-01-preview",

etc.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Todo
Development

No branches or pull requests

6 participants