← Telegram Bot + Salesforce (REST API) integrations

Add Contact to Campaign with Salesforce (REST API) API on New Message Updates (Instant) from Telegram Bot API

Pipedream makes it easy to connect APIs for Salesforce (REST API), Telegram Bot and 1000+ other apps remarkably fast.

Trigger workflow on
New Message Updates (Instant) from the Telegram Bot API
Next, do this
Add Contact to Campaign with the Salesforce (REST API) API
No credit card required
Into to Pipedream
Watch us build a workflow
Watch us build a workflow
7 min
Watch now ➜
Trusted by 250,000+ developers from startups to Fortune 500 companies:
Trusted by 250,000+ developers from startups to Fortune 500 companies

Developers Pipedream

Getting Started

This integration creates a workflow with a Telegram Bot trigger and Salesforce (REST API) action. When you configure and deploy the workflow, it will run on Pipedream's servers 24x7 for free.

  1. Select this integration
  2. Configure the New Message Updates (Instant) trigger
    1. Connect your Telegram Bot account
  3. Configure the Add Contact to Campaign action
    1. Connect your Salesforce (REST API) account
    2. Select a Campaign ID
    3. Select a Contact ID
  4. Deploy the workflow
  5. Send a test event to validate your setup
  6. Turn on the trigger

Details

This integration uses pre-built, open source components from Pipedream's GitHub repo. These components are developed by Pipedream and the community, and verified and maintained by Pipedream.

To contribute an update to an existing component or create a new component, create a PR on GitHub. If you're new to Pipedream component development, you can start with quickstarts for trigger span and action development, and then review the component API reference.

Trigger

Description:Emit new event each time a Telegram message is created or updated.
Version:0.1.3
Key:telegram_bot_api-message-updates

Telegram Bot Overview

With the Telegram Bot API, you can build bots that perform a variety of tasks,
including:

  • Sending and receiving messages
  • Social networking
  • Content management
  • File sharing
  • Location sharing
  • Bot administration
  • And more!

Trigger Code

import base from "../common/webhooks.mjs";

export default {
  ...base,
  key: "telegram_bot_api-message-updates",
  name: "New Message Updates (Instant)",
  description: "Emit new event each time a Telegram message is created or updated.",
  version: "0.1.3",
  type: "source",
  dedupe: "unique",
  methods: {
    ...base.methods,
    getMeta(event, message) {
      return {
        id: event.update_id,
        summary: message.text,
        ts: new Date(message.edit_date ?? message.date),
      };
    },
    getEventTypes() {
      return [
        "message",
        "edited_message",
      ];
    },
    processEvent(event) {
      const message = event.edited_message ?? event.message;
      this.$emit(event, this.getMeta(event, message));
    },
  },
};

Trigger Configuration

This component may be configured based on the props defined in the component code. Pipedream automatically prompts for input values in the UI and CLI.
LabelPropTypeDescription
Telegram BottelegramBotApiappThis component uses the Telegram Bot app.
N/Adb$.service.dbThis component uses $.service.db to maintain state between component invocations.
N/Ahttp$.interface.httpThis component uses $.interface.http to generate a unique URL when the component is first instantiated. Each request to the URL will trigger the run() method of the component.

Trigger Authentication

Telegram Bot uses API keys for authentication. When you connect your Telegram Bot account, Pipedream securely stores the keys so you can easily authenticate to Telegram Bot APIs in both code and no-code steps.

To use the Telegram Bot API, you must first create a new bot by chatting with the BotFather.


Telegram Bot how to

After you create your bot, copy the bot token and add it below.

About Telegram Bot

Telegram is a cloud-based instant messaging and voice over IP service

Action

Description:Adds an existing contact to an existing campaign. See [Event SObject](https://developer.salesforce.com/docs/atlas.en-us.228.0.object_reference.meta/object_reference/sforce_api_objects_campaignmember.htm) and [Create Record](https://developer.salesforce.com/docs/atlas.en-us.228.0.api_rest.meta/api_rest/dome_sobject_create.htm)
Version:0.0.2
Key:salesforce_rest_api-add-contact-to-campaign

Action Code

import salesForceRestApi from "../../salesforce_rest_api.app.mjs";
import {
  removeNullEntries, toSingleLineString,
} from "../../common/utils.mjs";
import constants from "../../common/constants.mjs";

export default {
  key: "salesforce_rest_api-add-contact-to-campaign",
  name: "Add Contact to Campaign",
  description: toSingleLineString(`
    Adds an existing contact to an existing campaign.
    See [Event SObject](https://developer.salesforce.com/docs/atlas.en-us.228.0.object_reference.meta/object_reference/sforce_api_objects_campaignmember.htm)
    and [Create Record](https://developer.salesforce.com/docs/atlas.en-us.228.0.api_rest.meta/api_rest/dome_sobject_create.htm)
  `),
  version: "0.0.2",
  type: "action",
  props: {
    salesForceRestApi,
    campaignId: {
      propDefinition: [
        salesForceRestApi,
        "sobjectId",
        () => ({
          objectType: constants.OBJECT_TYPE.CAMPAIGN,
        }),
      ],
      label: "Campaign ID",
      description: "ID of the Campaign to which this Lead is associated.",
    },
    contactId: {
      propDefinition: [
        salesForceRestApi,
        "sobjectId",
        () => ({
          objectType: constants.OBJECT_TYPE.CONTACT,
        }),
      ],
      label: "Contact ID",
      description: "ID of the Contact who is associated with a Campaign.",
    },
  },
  async run({ $ }) {
    const data = removeNullEntries({
      CampaignId: this.campaignId,
      ContactId: this.contactId,
    });
    const response = await this.salesForceRestApi
      .createObject(constants.OBJECT_TYPE.CAMPAIGN_MEMBER, data);
    response && $.export("$summary", "Successfully added contact to campaign");
    return response;
  },
};

Action Configuration

This component may be configured based on the props defined in the component code. Pipedream automatically prompts for input values in the UI.

LabelPropTypeDescription
Salesforce (REST API)salesForceRestApiappThis component uses the Salesforce (REST API) app.
Campaign IDcampaignIdstringSelect a value from the drop down menu.
Contact IDcontactIdstringSelect a value from the drop down menu.

Action Authentication

Salesforce (REST API) uses OAuth authentication. When you connect your Salesforce (REST API) account, Pipedream will open a popup window where you can sign into Salesforce (REST API) and grant Pipedream permission to connect to your account. Pipedream securely stores and automatically refreshes the OAuth tokens so you can easily authenticate any Salesforce (REST API) API.

Pipedream requests the following authorization scopes when you connect your account:

About Salesforce (REST API)

Web services API for interacting with Salesforce

More Ways to Connect Salesforce (REST API) + Telegram Bot

Delete a Message with Telegram Bot API on New Object (of Selectable Type) from Salesforce (REST API) API
Salesforce (REST API) + Telegram Bot
 
Try it
Edit a Media Message with Telegram Bot API on New Object (of Selectable Type) from Salesforce (REST API) API
Salesforce (REST API) + Telegram Bot
 
Try it
Edit a Text Message with Telegram Bot API on New Object (of Selectable Type) from Salesforce (REST API) API
Salesforce (REST API) + Telegram Bot
 
Try it
Forward a Message with Telegram Bot API on New Object (of Selectable Type) from Salesforce (REST API) API
Salesforce (REST API) + Telegram Bot
 
Try it
Get the Number of Members in a Chat with Telegram Bot API on New Object (of Selectable Type) from Salesforce (REST API) API
Salesforce (REST API) + Telegram Bot
 
Try it
New Bot Command Received (Instant) from the Telegram Bot API

Emit new event each time a Telegram Bot command is received.

 
Try it
New Channel Updates (Instant) from the Telegram Bot API

Emit new event each time a channel post is created or updated.

 
Try it
New Message Updates (Instant) from the Telegram Bot API

Emit new event each time a Telegram message is created or updated.

 
Try it
New Updates (Instant) from the Telegram Bot API

Emit new event for each new Telegram event.

 
Try it
New Deleted Object (Instant, of Selectable Type) from the Salesforce (REST API) API

Emit new event immediately after an object of arbitrary type (selected as an input parameter by the user) is deleted

 
Try it
Create Chat Invite Link with the Telegram Bot API

Create an additional invite link for a chat, See the docs for more information

 
Try it
Delete a Message with the Telegram Bot API

Deletes a message. See the docs for more information

 
Try it
Edit a Media Message with the Telegram Bot API

Edits photo or video messages. See the docs for more information

 
Try it
Edit a Text Message with the Telegram Bot API

Edits text or game messages. See the docs for more information

 
Try it
Export Chat Invite Link with the Telegram Bot API

Generate a new primary invite link for a chat, See the docs for more information

 
Try it