Publish

Publishing is the process of putting your bot on InterBot so that other bots can send and receive messages to your bot.

  • If you have built your bot on Gupshup, publishing to InterBot is a simple process. Here are the steps to do so:

    1. Go to the ‘My Bots’ section on gupshup.io

    2. Click on the ‘Publish’ tab corresponding to the bot that you want published

    3. Scroll to the bottom and hit the ‘Enable’ button next to InterBot. In case you see the “To enable your bot for InterBot, you will need to first deploy your Bot” error, open the bot and hit the ‘deploy’ button on your IDE.

    4. Your bot is now published on the InterBot channel. You can send and receive messages from other bots now.

  • To publish a bot that was not built on the Gupshup platform, you will need to use the InterBot Publish API along with a HTTP callback. A callback is required to send and receive messages via the InterBot channel. When a third-party bot sends a message to your bot, a request is sent to this callback URL.

Here are the API details:

POST https://ibc.interbot.cc/ibc/bot/{botname}/publish

Parameters

apikey:The apikey of your InterBot account. Obtain this by clicking on your profile photo in the top right corner of the browser window

botname: The name of the bot to be published

callbackUrl: The HTTP callback URL

A return status of 200 indicates that the bot has successfully been published. You can find the Swagger specs for the API here.

function MessageHandler(context, event) { } function EventHandler(context, event) { } function HttpResponseHandler(context, event) { } function DbGetHandler(context, event) { } function DbPutHandler(context, event) { }
function MessageHandler(context, event) { var channelName = event.contextobj.channeltype; var senderName = event.senderobj.channelid; context.console.log("refid : "+refid+" ; senderName : "+senderName); var ibcbots = botmap.split("|"); var position = ibcbots.indexOf("@"+senderName); var nextBot = ibcbots[position+1] var lastBot = ibcbots[ibcbots.length-1].replace(/@/g,""); context.console.log("nextBot : "+nextBot); if(channelName == "ibc"){ var refid = event.contextobj.refid; if(position < 0 && senderName!=botName){ //IBC Init Point if(!context.simpledb.botleveldata[refid]){ context.simpledb.botleveldata[refid]=senderName; context.simpledb.saveData(sendIBCMessage(context,ibcbots[0].replace(/@/g,""),refid,event.message)); }else{ delete(context.simpledb.botleveldata[refid]) return; } }else if(nextBot){ sendIBCMessage(context,nextBot.replace(/@/g,""),refid,event.message); }else{ recBotname = context.simpledb.botleveldata[refid]; try{ var userContext = JSON.parse(recBotname); delete context.simpledb.botleveldata[refid]; context.simpledb.saveData(sendMsg(context,recBotname,event.message)); }catch(err){ delete context.simpledb.botleveldata[refid]; context.simpledb.saveData(sendIBCMessage(context,recBotname,refid,event.message)); } } }else{ var _event = event; var _context = context; generateRefid(function(context,event){ var refid = String(event.getresp); context.simpledb.botleveldata[refid] = JSON.stringify(_event.contextobj); context.simpledb.saveData(sendIBCMessage(context,ibcbots[0].replace(/@/g,""),refid,_event.message)); }); } } function generateRefid(cb){ var url = envurl+botName+'/refid'; var headers = { 'content-type': 'application/x-www-form-urlencoded', 'apikey': apikey } context.simplehttp.makePost(url, "", headers,cb); } function sendIBCMessage(context,recipientName,refid,message) { var url = envurl+botName+'/sendmsg'; var headers = { 'content-type': 'application/x-www-form-urlencoded', 'apikey': apikey } var formData = 'refid=' + refid + '&message=' + message+'&destbotname='+recipientName; context.simplehttp.makePost(url, formData, headers); } function sendMsg(context,userContext,message){ var url = botenvurl+botName+'/msg'; var headers = { 'content-type': 'application/x-www-form-urlencoded', 'apikey': apikey } var formData = 'context=' + userContext + '&message=' + message+"&bypass=true"; context.simplehttp.makePost(url, formData, headers); } /** Functions declared below are required **/ function EventHandler(context, event) {} function HttpResponseHandler(context, event) {} function DbGetHandler(context, event) {} function DbPutHandler(context, event) {}