Skip to main content

Send speaker and proposal information to SalesForce

Project description

This is a plugin for pretalx that serves to send speaker and proposal information to SalesForce.

Information is sent every eight hours or on manual sync, and is mapped as follows:

  • Users and their speaker profiles are sent as contacts:
    • Contact.pretalx_LegacyID__c is set to the pretalx user ID

    • Contact.FirstName is set to the first part of a user’s name, separated by whitespace.

    • Contact.LastName is set to any remaining part of a user’s name.

    • Contact.Email is set to the user’s email address.

    • Contact.Biography__c is set to the user’s biography.

    • Contact.pretalx_Profile_Picture__c is set to the user’s profile picture URL.

  • Submission objects are set synced to the custom Session object:
    • CreatedDate is set to the submission’s creation date.

    • pretalx_LegacyID__c is set to the submission’s pretalx ID.

    • Name is set to the submission’s title.

    • Session_Title__c is the submission’s full title, as Name is truncated to 80 characters.

    • Track__c is set to the submission’s track (by name, not by ID).

    • Submission_Format__c is set to the submission’s type (by name, not by ID).

    • Status__c is set to the submission’s status.

    • Abstract__c is set to the submission’s abstract plus the submission’s description, separated by two newlines and then stripped of whitespace.

    • Pretalx_Record__c is set to the submission’s public URL.

  • The mapping between Contacts and Sessions is synced to the custom Contact_Session__c object:
    • Contact__c is set to the Salesforce Contact.

    • Session__c is set to the Salesforce Session.

Development setup

  1. Make sure that you have a working pretalx development setup.

  2. Clone this repository, eg to local/pretalx-salesforce.

  3. Activate the virtual environment you use for pretalx development.

  4. Run pip install -e . within this directory to register this application with pretalx’s plugin registry.

  5. Run make within this directory to compile translations.

  6. Restart your local pretalx server. This plugin should show up in the plugin list shown on startup in the console. You can now use the plugin from this repository for your events by enabling it in the ‘plugins’ tab in the settings.

This plugin has CI set up to enforce a few code style rules. To check locally, you need these packages installed:

pip install flake8 flake8-bugbear isort black

To check your plugin for rule violations, run:

black --check .
isort -c .
flake8 .

You can auto-fix some of these issues by running:

isort .
black .

License

Copyright 2024 Tobias Kunze

Released under the terms of the Apache License 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pretalx_salesforce-0.1.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pretalx_salesforce-0.1.0-py3-none-any.whl (51.2 kB view details)

Uploaded Python 3

File details

Details for the file pretalx_salesforce-0.1.0.tar.gz.

File metadata

  • Download URL: pretalx_salesforce-0.1.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for pretalx_salesforce-0.1.0.tar.gz
Algorithm Hash digest
SHA256 79739cc3ef1612fdaf19bdf7fb8ae9c6cff8a98e6504cdb7db9168699723c6a7
MD5 82a456e614210d843d3806e850afe1fc
BLAKE2b-256 6cacc9035eebfd2cfa40bdedae3d6f73972b0436d5b4d9e5c045cb2e6cae7472

See more details on using hashes here.

File details

Details for the file pretalx_salesforce-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pretalx_salesforce-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0f6ad47ba01cc1ec1bab43dae8afa17624b762c69845fa71429cbba8a9b7a961
MD5 52c4fe88e92dba5a5d9dbdf4981aaf38
BLAKE2b-256 405382f36422616f4e1c2cdee876056229fee5ab3bba04e62dc65c20c4b75610

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page