Skip to main content

TypeError: Provided value for 'message' must be of type: ServiceBusMessage in a Service Bus Queue Azure

I have the following code that connects a JSON file with an Azure Service Bus Trigger but when the trigger is activated I encounter the error TypeError: Provided value for 'message' must be of type: ServiceBusMessage. I have found the following link that provides some sort of help but it wasn't that useful How to specify content type as application/json while sending message to azure service bus queue in node js?

module.exports = async function (context, myBlob) {
    context.log("JavaScript blob trigger function processed blob \n Blob:", context.bindingData.blobTrigger, "\n Blob Size:", myBlob.length, "Bytes");
    if(context.bindingData.name.indexOf("json_results") == -1){
        context.log(context.bindingData.name);
        return;
    }

const data = JSON.parse(myBlob.toString());
context.log(data);

// service bus queue
const { ServiceBusClient } = require("@azure/service-bus");
// connection string to your Service Bus namespace
const connectionString = "Endpoint=sb://servicebus.servicebus.windows.net/;SharedAccessKeyName=RootManageSharedAccessKey;SharedAccessKey=xxxxx";



const sbClient = new ServiceBusClient(connectionString);

// name of the queue
const queueName = "service-bus-queue";
context.log("Creating queue: ", queueName);

const sender = sbClient.createSender(queueName)


try{
    // Tries to send all messages in a single batch.
    // Will fail if the messages cannot fit in a batch.
    // await sender.sendMessages(messages);
    let batch = await sender.createMessageBatch();
    for (let index=0; index < data.length; index++){
        // for each message in the array            
        // try to add the message to the batch
        if (!batch.tryAddMessage(data[index])) {            
            // if it fails to add the message to the current batch
            // send the current batch as it is full
            await sender.sendMessages(batch);

            // then, create a new batch 
            batch = await sender.createMessageBatch();

            // now, add the message failed to be added to the previous batch to this batch
            if (!batch.tryAddMessage(data[index])) {
                // if it still can't be added to the batch, the message is probably too big to fit in a batch
                throw new Error("Message too big to fit in a batch");
            }
        }
    }
    // Send the last created batch of messages to the queue
    await sender.sendMessages(batch);

    context.log(`Sent a batch of messages to the queue: ${queueName}`);

    // Close the sender
    await sender.close();
} finally {
    await sbClient.close();
}

};

How do I convert this JSON file properly so it can be sent correctly to the Service Bus?

This is some sample data from the JSON file:

[
    {
    "Id": "MCMID|10091810600907894473354109933466533357",
    "FC_rev": 0.0,
    "FC_seg": 0.0,
    "MC_rev": 0.0,
    "MC_seg": 0.0,
    "PC_rev": 0.0,
    "PC_seg": 0.0,
    "PNR_booking": 0,
    "SP_ID_f": "1009181060090789447335410993346653335721632922568DCABOI",
    "Saver_rev": 439.08,
    "Saver_seg": 8.0,
    "Total_seg": 8.0,
    "num_PAX": 2,
    "EndUserID": "oeu1632860659758r0.8453951976577427",
    "purchase_time_": "00000000000000"
},
{
    "Id": "MCMID|1015698875809402563583619705251328622",
    "FC_rev": 0.0,
    "FC_seg": 0.0,
    "MC_rev": 160.0,
    "MC_seg": 2.0,
    "PC_rev": 0.0,
    "PC_seg": 0.0,
    "PNR_booking": 0,
    "SP_ID_f": "101569887580940256358361970525132862211632922598LAXZLO",
    "Saver_rev": 0.0,
    "Saver_seg": 0.0,
    "Total_seg": 2.0,
    "num_PAX": 1,
    "EndUserID": "oeu1632922592097r0.5015812337790303",
    "purchase_time_": "00000000000000"
},
{
    "Id": "MCMID|1015698875809402563583619705251328622",
    "FC_rev": 150.08369127516778,
    "FC_seg": 1.0,
    "MC_rev": 99.77630872483222,
    "MC_seg": 1.0,
    "PC_rev": 0.0,
    "PC_seg": 0.0,
    "PNR_booking": 0,
    "SP_ID_f": "101569887580940256358361970525132862211632922598PDXLAX",
    "Saver_rev": 0.0,
    "Saver_seg": 0.0,
    "Total_seg": 2.0,
    "num_PAX": 1,
    "EndUserID": "oeu1632922592097r0.5015812337790303",
    "purchase_time_": "00000000000000"
    }
]
Via Active questions tagged javascript - Stack Overflow https://ift.tt/2FdjaAW

Comments

Popular posts from this blog

Confusion between commands.Bot and discord.Client | Which one should I use?

Whenever you look at YouTube tutorials or code from this website there is a real variation. Some developers use client = discord.Client(intents=intents) while the others use bot = commands.Bot(command_prefix="something", intents=intents) . Now I know slightly about the difference but I get errors from different places from my code when I use either of them and its confusing. Especially since there has a few changes over the years in discord.py it is hard to find the real difference. I tried sticking to discord.Client then I found that there are more features in commands.Bot . Then I found errors when using commands.Bot . An example of this is: When I try to use commands.Bot client = commands.Bot(command_prefix=">",intents=intents) async def load(): for filename in os.listdir("./Cogs"): if filename.endswith(".py"): client.load_extension(f"Cogs.{filename[:-3]}") The above doesnt giveany response from my Cogs ...

How to show number of registered users in Laravel based on usertype?

i'm trying to display data from the database in the admin dashboard i used this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count(); echo $users; ?> and i have successfully get the correct data from the database but what if i want to display a specific data for example in this user table there is "usertype" that specify if the user is normal user or admin i want to user the same code above but to display a specific usertype i tried this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count()->WHERE usertype =admin; echo $users; ?> but it didn't work, what am i doing wrong? source https://stackoverflow.com/questions/68199726/how-to-show-number-of-registered-users-in-laravel-based-on-usertype

Why is my reports service not connecting?

I am trying to pull some data from a Postgres database using Node.js and node-postures but I can't figure out why my service isn't connecting. my routes/index.js file: const express = require('express'); const router = express.Router(); const ordersCountController = require('../controllers/ordersCountController'); const ordersController = require('../controllers/ordersController'); const weeklyReportsController = require('../controllers/weeklyReportsController'); router.get('/orders_count', ordersCountController); router.get('/orders', ordersController); router.get('/weekly_reports', weeklyReportsController); module.exports = router; My controllers/weeklyReportsController.js file: const weeklyReportsService = require('../services/weeklyReportsService'); const weeklyReportsController = async (req, res) => { try { const data = await weeklyReportsService; res.json({data}) console...