This is a guide for developing apps to integrate external systems with Gladly using the App Platform.
Continue using Lookup Adaptor for Glady Hero integrations
Currently, if you aim to enable Agents to access and engage with data in Gladly Hero, you must create a Lookup Adaptor instead of building integrations using App Platform. Leveraging this data within Gladly Sidekick is relatively simple. However, this process might necessitate specific adjustments to ensure data compatibility and effectiveness. For instance, all date formats must adhere strictly to the ISO8601 standard.
In Gladly, an App provides a mechanism for tightly integrating outside systems into the Gladly platform. While these capabilities will grow over time, Apps allow you to extend Gladly Sidekick by performing Actions in and retrieving custom data from external systems. Tools like appcfg can help you develop, test, and build Gladly App Platform applications.
By giving Sidekick access to data and Actions in the systems you use to run your business, Gladly can assist your Customers in serving themselves in common service workflows.
For example, an order management system may have APIs for retrieving, updating, and canceling orders. An App would include the configuration for retrieving orders for a specific Gladly Customer, enabling Gladly Sidekick to update and cancel those orders without requiring assistance from an Agent.
The configuration for Actions and Data Pulls is described in detail in the docs below.
To expose a “Cancel Order” Action, the App must be configured to connect to your existing RESTful APIs. To accomplish this, add a sub-folder to the actions/ folder within your App with three files inside:
[action_name]/config.json
[action_name]/request_url.gtpl
actions_schema.graphql
# ./your_app/actions/actions_schema.graphql
type Response {
"""
Whether or not the action succeeded
"""
success: Boolean!
}
type Mutation {
"""
Cancel an order using the order id
"""
cancelOrder(orderId: String!): Response @action(name: "cancel_order")
}
In this template, the relevant Customer Profile data is provided to the template via the .customer attribute, and the primary email address is accessed using the {{.customer.primaryEmailAddress}} go template syntax. This will be explained in greater detail in a subsequent section of this document.
Apps use GraphQL schemas to describe the type signatures of requests and responses. Gladly uses these types of signatures to determine how to display Actions and data within the product user interface.
Sample GraphQL type definition for a simple order
type Order {
orderId: String
orderDate: DateTime
}
Gladly Apps make use of semantic versioning. Providing versions for key portions of your configuration is how you let Gladly know the current state of your application and when your app evolves. The goal is to always make backward-compatible changes to your app whenever possible so that everything keeps working in Gladly as your app evolves.
An App is at least gzip’d folder with a manifest.json file in it. In addition, there are three other top-level resource folders an app can optionally have:
An actions/ folder – contains configuration for the Actions the App can run.
A data/ folder – contains configuration for the data pulls the App can perform.
An authentication/ folder – contains information about how to authenticate all the HTTP requests an app makes.
External systems tend to use one authentication scheme for all REST calls, so Apps share authentication configuration across both Actions and data pulls.
The authentication/ folder contains configuration for the various authentication schemes that Gladly supports when making REST calls to external systems.
Currently, the only supported authentication scheme is header-based authentication. This is configured within the authentication/headers/ folder. In this folder, template files are named after the headers for which they create values; i.e. [header-name].gtpl.
This website uses cookies to improve your experience while you navigate through the website. Out of these cookies, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may have an effect on your browsing experience.
Necessary cookies are absolutely essential for the website to function properly. These cookies ensure basic functionalities and security features of the website, anonymously.
Cookie
Duration
Description
__cf_bm
29 minutes
This cookie, set by Cloudflare, is used to support Cloudflare Bot Management.
_wpfuuid
1 year 1 month 4 days
This cookie is used by the WPForms WordPress plugin. The cookie is used to allows the paid version of the plugin to connect entries by the same user and is used for some additional features like the Form Abandonment addon.
BIGipServer*
session
Marketo sets this cookie to collect information about the user's online activity and build a profile about their interests to provide advertisements relevant to the user.
cookielawinfo-checkbox-advertisement
1 year
Set by the GDPR Cookie Consent plugin, this cookie records the user consent for the cookies in the "Advertisement" category.
cookielawinfo-checkbox-analytics
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Analytics".
cookielawinfo-checkbox-functional
11 months
The cookie is set by GDPR cookie consent to record the user consent for the cookies in the category "Functional".
cookielawinfo-checkbox-necessary
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookies is used to store the user consent for the cookies in the category "Necessary".
cookielawinfo-checkbox-others
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Other.
cookielawinfo-checkbox-performance
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Performance".
CookieLawInfoConsent
1 year
CookieYes sets this cookie to record the default button state of the corresponding category and the status of CCPA. It works only in coordination with the primary cookie.
PHPSESSID
session
This cookie is native to PHP applications. The cookie stores and identifies a user's unique session ID to manage user sessions on the website. The cookie is a session cookie and will be deleted when all the browser windows are closed.
viewed_cookie_policy
11 months
The cookie is set by the GDPR Cookie Consent plugin and is used to store whether or not user has consented to the use of cookies. It does not store any personal data.
Functional cookies help to perform certain functionalities like sharing the content of the website on social media platforms, collect feedbacks, and other third-party features.
Cookie
Duration
Description
li_gc
5 months 27 days
Linkedin set this cookie for storing visitor's consent regarding using cookies for non-essential purposes.
lidc
1 day
LinkedIn sets the lidc cookie to facilitate data center selection.
UserMatchHistory
1 month
LinkedIn sets this cookie for LinkedIn Ads ID syncing.
Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.
Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics the number of visitors, bounce rate, traffic source, etc.
Cookie
Duration
Description
_ga
1 year 1 month 4 days
Google Analytics sets this cookie to calculate visitor, session and campaign data and track site usage for the site's analytics report. The cookie stores information anonymously and assigns a randomly generated number to recognise unique visitors.
_ga_*
1 year 1 month 4 days
Google Analytics sets this cookie to store and count page views.
_gd_session
4 hours
This cookie is used for collecting information on users visit to the website. It collects data such as total number of visits, average time spent on the website and the pages loaded.
_gd_visitor
1 year 1 month 4 days
This cookie is used for collecting information on the users visit such as number of visits, average time spent on the website and the pages loaded for displaying targeted ads.
_sp_id.*
1 year 1 month 4 days
Snowplow sets this cookie to store user information that is created when a user first visits a site and is updated on subsequent visits.
_sp_ses.*
30 minutes
Snowplow sets this cookie to store user information that is created when a user first visits a site and is updated on subsequent visits.
AnalyticsSyncHistory
1 month
Linkedin set this cookie to store information about the time a sync took place with the lms_analytics cookie.
mf_user
3 months
Mouseflow sets this cookie to identify whether a visitor is new or returning.
vuid
1 year 1 month 4 days
Vimeo installs this cookie to collect tracking information by setting a unique ID to embed videos on the website.
Advertisement cookies are used to provide visitors with relevant ads and marketing campaigns. These cookies track visitors across websites and collect information to provide customized ads.
Cookie
Duration
Description
_mkto_trk
1 year 1 month 4 days
This cookie, provided by Marketo, has information (such as a unique user ID) that is used to track the user's site usage. The cookies set by Marketo are readable only by Marketo.
bcookie
1 year
LinkedIn sets this cookie from LinkedIn share buttons and ad tags to recognize browser IDs.
bscookie
1 year
LinkedIn sets this cookie to store performed actions on the website.
li_sugr
3 months
LinkedIn sets this cookie to collect user behaviour data to optimise the website and make advertisements on the website more relevant.