Speakers Query

Arguments

gatheringId: (Int!)
id: (Int!)
speaker: (SpeakerParams)
CURL Request
curl -X POST http://localhost:4000/graphql -H 'Content-Type: application/graphql' -H 'Authorization: Bearer 123abcveryLongAuthorizationToken456def' -d '{speakers(gatheringId: 232) {firstName lastName}}'

This query will return the lastName, id, and externalId for each speaker.

Query Example
{
  speakers(gatheringId: 4422) {
    firstName
    lastName
    id
    externalId
  }
}
CURL Request
curl -X POST http://localhost:4000/graphql -H 'Content-Type: application/graphql' -H 'Authorization: Bearer 123abcveryLongAuthorizationToken456def' -d '{ speakers(gatheringId: 232) { firstName lastName id externalId bookmarkedAgendaSessions { name startsAt endsAt id externalId } surveyResponses {id answers { id question { id name questionData questionType} answer }}}}'

SpeakerParams

Attributes

firstName (String) Speaker first name. Displayed if present.
lastName (String) Speaker last name. Displayed if present.
prefix_name (String) Speaker honorific (Mr., Ms., Dr.). Displayed if present.
suffix_name (String) Speaker suffix (Jr., Sr., Md., Phd). Displayed if present.
kind (String) Speaker kind (Keynote, Workshop). Displayed if present.
login_email (String) Email used to login. Not displayed.
organization (String) Speaker organization or company. Displayed if present.
job_title (String) Speaker organization or company. Displayed if present.
email (String) Speaker email. Displayed if present. Not related to the login email.
fax (String) Speaker kind (Keynote, Workshop). Displayed if present.
telephone (String) Speaker preferred telephone number. Displayed if present.
website (String) Speaker URL. Displayed if present.
twitterHandle (String) Speaker Twitter handle. @ is optional. Displayed if present.
facebookUsername (String) Speaker Facebook username. Not a URL. Displayed if present.
linkedInUrl (String) Speaker LinkedIn URL. Displayed if present.
street (String) Speaker Street (3722 Maplehurst Drive). Displayed if present.
street2 (String) Speaker Street - supplemental (e.g., Suite 181). Displayed if present.
city (String) Speaker last name. Displayed if present.
state (String) Speaker's state or province. Displayed if present.
postalCode (String) Speaker's Postal or ZIP code. Displayed if present.
country (String) Speaker's country. Displayed if present.
biography (String) Speaker biography in HTML format. Distinct from BiographyText. Displayed if present. Not editable by speaker.
hidden (Boolean) If this boolean is set to true, this speaker will not be visible in the mobile app and cannot participate socially.
externalId (String) The unqiue ID of the speaker from it\'s source (i.e., the speaker id in your system). Not displayed.
externalSource (String) External data source of the speaker. If you have created this speaker in the Touchpoint system, Touchpoint will define the externalSource. Not displayed.

Providing a Photo/Avatar

You may supply a speaker photo in several ways. Using the photoUrl attribute, you may supply a URL. Using the photo attribute you may supply either a Base64 encoded string or an image file using the multipart/form-data content type. An image file is preferred to the Base64 string as it will be smaller.

photoUrl (String) If the photo resides at a publicly available URL, you may provide that URL here (.jpg or .png format). The image at that URL will be copied into the Touchpoint system.

photo (DataUpload) Choose multipart file (preferred) and Base64:

To provide the photo as a file, you should use the multipart/form-data content type. For example:

curl -X POST https://cms.gatherdigital.com/graphql -H 'Content-Type: application/graphql' -H 'Authorization: Bearer 123abcveryLongAuthorizationToken456def' -F query='mutation { createSpeaker(speaker: { firstName: "David Foster", lastName: "Wallace", photo: "photo_argument"}, gatheringId: 232) { firstName lastName id }' -F photo_argument=@photo.jpg
Notice that the value of the photo attribute is the name of the argument used to refer to the photo file

To provide the photo file as a Base64 encoded string, prefix the photo string with the information:
data:<mime type>;base64,<encoded data>
For example:

curl -X POST https://cms.gatherdigital.com/graphql -H 'Content-Type: application/graphql' -H 'Authorization: Bearer 123abcveryLongAuthorizationToken456def' -d '{ mutation { createSpeaker(speaker: { firstName: "David Foster", lastName: "Wallace", photo: ""}, gatheringId: 232) { firstName lastName id } }'