Интеграция Salesforce с мобильным приложением

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Интеграция Salesforce с мобильным приложением
Средняя
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1054
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    874
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Интеграция Salesforce с мобильным приложением

Salesforce — зрелая CRM-платформа с хорошо задокументированным REST API и несколькими SDK для мобильных. В отличие от 1С или Битрикс24, здесь меньше неожиданных ограничений API, зато больше концепций для изучения: Connected App, OAuth 2.0 flows, SOQL, SOSL, Apex REST, Platform Events.

Connected App и OAuth

Всё начинается с создания Connected App в Salesforce Setup: App Manager → New Connected App. Указываешь Callback URL (deeplink приложения), включаешь OAuth scopes: api, refresh_token offline_access.

Мобильное приложение использует OAuth 2.0 Authorization Code Flow или JWT Bearer Flow для server-to-server. Для пользовательского контекста — Authorization Code.

На Android — AppAuth библиотека:

val serviceConfig = AuthorizationServiceConfiguration(
    Uri.parse("https://login.salesforce.com/services/oauth2/authorize"),
    Uri.parse("https://login.salesforce.com/services/oauth2/token")
)

val request = AuthorizationRequest.Builder(
    serviceConfig,
    clientId,
    ResponseTypeValues.CODE,
    Uri.parse("myapp://oauth/callback")
).setScope("api refresh_token offline_access").build()

authService.performAuthorizationRequest(request, pendingIntent)

После обмена кода на токен сохраняем access_token, refresh_token и instance_url — базовый URL для всех API-вызовов (у каждого Salesforce орга свой поддомен).

REST API и SOQL

Salesforce REST API — главный интерфейс. Базовый URL: {instance_url}/services/data/v60.0/. Версию API выбирай под минимально поддерживаемый Salesforce API версию у клиента.

Запрос через SOQL (Salesforce Object Query Language):

GET /services/data/v60.0/query/?
  q=SELECT+Id,Name,Amount,StageName,CloseDate,Account.Name
  +FROM+Opportunity
  +WHERE+OwnerId='{userId}'+AND+IsClosed=false
  +ORDER+BY+CloseDate+ASC+LIMIT+50

SOQL — SQL-подобный язык, но со своими ограничениями: нет JOIN в обычном понимании, связанные объекты через relationship query (Account.Name). LIMIT максимум 2000. Для больших наборов — queryMore с nextRecordsUrl из ответа.

Создание записи — POST /services/data/v60.0/sobjects/Opportunity/ с JSON-телом. Обновление — PATCH /services/data/v60.0/sobjects/Opportunity/{id}. Важно: Salesforce использует PATCH, не PUT для обновления.

Platform Events для real-time

Salesforce Platform Events — publish/subscribe механизм. Сервер публикует событие (OpportunityUpdated__e), клиенты получают через CometD (Bayeux протокол, long polling).

На мобильном — Salesforce Mobile SDK или собственная реализация CometD. Mobile SDK включает готовый SFRestAPI и StreamingAPI клиент. Но SDK тяжёлый — 15+ МБ, что критично для некоторых проектов.

Лёгкая альтернатива: кастомный CometD клиент на OkHttp:

val cometdClient = BayeuxClient(
    "${instanceUrl}/cometd/60.0",
    LongPollingTransport.create(null, okHttpClient)
)
cometdClient.handshake()
cometdClient.getChannel("/event/OpportunityUpdated__e")
    .subscribe { message ->
        val payload = message.dataAsMap
        handleOpportunityUpdate(payload)
    }

При обновлении сделки в Salesforce → Platform Event → CometD → мобильный клиент обновляет экран. Latency: 1-3 секунды.

Salesforce Mobile SDK vs кастомная интеграция

Salesforce Mobile SDK Кастомная интеграция
OAuth Встроен AppAuth / кастомный
Offline SmartStore (SQLCipher) Room / Core Data
Push Встроен FCM/APNs напрямую
Размер +15 МБ Минимальный
Гибкость Ограничена SDK Полная

SDK оправдан, если приложение преимущественно Salesforce-ориентировано. Для приложений, где Salesforce — одна из нескольких интеграций — лучше кастомный подход.

Salesforce Files и вложения

Файлы в Salesforce — ContentDocument и ContentVersion. Загрузка файла из мобильного приложения:

POST /services/data/v60.0/sobjects/ContentVersion/
Content-Type: multipart/form-data

{
  "Title": "Фото клиента",
  "PathOnClient": "photo.jpg",
  "FirstPublishLocationId": "{opportunityId}"
}
+ binary data

FirstPublishLocationId — объект, к которому привязывается файл. Ограничение: один файл за запрос. Для загрузки нескольких — последовательные запросы или Salesforce Bulk API.

Сроки

Базовая интеграция (OAuth, SOQL-запросы, CRUD для Opportunity/Contact): 1-2 недели. Platform Events, offline-кэш, push-уведомления: плюс 1-2 недели. Полноценное приложение с Salesforce Mobile SDK, SmartStore и синхронизацией: 1,5-2 месяца. Стоимость рассчитывается индивидуально.