Support Tools
When you first start in support, the list of tools to set-up can feel like a lot. This document explains how they add value for you, (when relevant) how they fit together, and a deep dive on Zendesk.
Internal collaboration
- Slack is our primary communication tool.
- GitHub is where our handbook lives.
- Zoom is how we connect synchronously.
- Gmail is mostly for notifications.
- Google calendar is for your calendar, as well as shared calendars (like the CS team calendar).
- Gsuite is for drafts, slide decks, and spreadsheets.
- Lattice is to facilitate our twice yearly review cycles.
- Greenhouse is for hiring.
- Grammarly and Hemingwayapp help us say what we intend.
- Otter.ai makes it easier for everyone to follow along during Zoom calls.
All things customers
- Zendesk is where we manage our day-to-day work and interact with some customers.
- Slack is where we interact with most customers.
- Salesforce is our source of truth for customer data.
- Looker is our data warehouse so we can connect different data sources and analyze anything we need to.
- ProductBoard is where we collect all feedback about the product.
- Calendly is useful when you need to schedule a call with a customer.
- Krisp quiets background noise when on Zoom.
- Grammarly and Hemingwayapp help us say what we intend and catch any typos we don’t see.
sourcegraph.com admin access
- In Entitle, request the Dotcom site admin permission. You may do this using the /access_request Slack command or this pre-filled request.
- Go to https://sourcegraph.com/sign-in?sourcegraph-operator
- Click on Other login methods
- Click on Continue with Sourcegraph Operators
- Authenticate with Okta
Managed instance access
Refer to the managed instance dashboard. You can find specific instructions for requesting access to the respective Cloud infrastructure via the “Ops” link provided in the dashboard. Access permissions are managed through Entitle.
Test Environments
There are some test environments created specifically for the CS team to run tests on when helping customers. They allow the team to reproduce and debug issues without affecting our production instances.
External DNS Sourcegraph Instances
- Test instance deployed with Docker Compose (management doc)
- Test instance deployed with Kubernetes (management doc)
Add a maintenance notice to the Global settings if you are testing, experimenting or upgrading cse-k8s or cse-aws-test.
"notices": [
{
"location": "top",
"message": "This instance is down for maintenance."
},
Local Sourcegraph Instances
Code Host Instances
Troubleshooting
Troubleshooting Guide for Support
The Zendesk Troubleshooting guide contains set of guides to help the team identify and resolve issues or problems.
GitHub Repository for Support Tools
The Support Tools GitHub Repository contains tools built by the CS team that provide values when supporting our customers. This repository is private, and you are welcome to add your projects to this repository, but please speak to Aimee about your ideas and plans before development starts to avoid possible conflicts.
Command Line Generator
The Command Line Generator is a simple web app that supports can use to generate the most frequently used commands for different deployment type when supporting a customer.
Sourcegraph Graphql Voyager
Sourcegraph Graphql Voyager is a bootstraped tool that allows users to visually explore the Sourcegraph GraphQL API as an interactive graph.
Go to https://cors-anywhere.herokuapp.com/corsdemo and press “request temporary access to the demo server”.
Enter your Sourcegraph.com access token and click “Submit”.
Sourcegraph Debugging Sheet (WIP)
Sourcegraph Debugging Sheet is a cheatsheet designed to streamline the troubleshooting process by allowing the CS team to search for common topics discussed with our customers and first steps at troubleshoot them.
How to use:
- Go to Cors Demo to opt-in for temporary
Cors Anywhere
access by clicking on the Request temporary access to the demo server button - Enter your Sourcegraph Token on homescreen
Scripts
Creating customized scripts can help automate a repetitive task for the team and the customers. You can find all the existing scripts in this directory and are welcome to write and share your own custom scripts with the team.
Sourcegraph logging, services, and observability
Designed to be an overview of Sourcegraph services and architecture. Topics include observability resources and logging. Covers when, what and how to to gather logs. Includes log interpretation examples.
Zendesk
This section captures our Zendesk protocol and configuration decisions.
Access
- Support engineers have agent access
- CS leadership and Tech Ops have admin access
- Only Shawnteé can modify billing related items
- We have an admin level service account support engineers can use for integration work with Zendesk. If you want to do anything with this account, please check with @cs-leadership in our #team-customer-support Slack channel first (they will help make sure what you want to do won’t interrupt other workflow settings); similarly, this account should not used to make configuration changes without checking with the leadership team who is responsible for Zendesk configuration
- Tickets are also rendered via an iFrame in Salesforce for CE and Sales access.
Web vs desktop vs mobile app
The best way to use Zendesk as an agent is via the web app. The mobile app is nice, but installing such apps on your phone can make it harder to take a break from work. Really consider this before you download the app to your phone. The desktop app is very limited and best to not even bother with.
When to be logged in and monitoring the queue
Due to us being a global team and covering 24x5 we all work different schedules. You are expected to work your normal defined schedule unless a heads up has been given to the team. Our shift process allows for specific members of the team keep track of tickets coming in while the rest concentrate on their current workload.
Notifications
Set your notifications however you see fit to make sure you are able to help monitor the queue.
Views
When you log into Zendesk, all tickets are organized by the following views:
- Unassigned tickets. All new tickets that no one on the team has taken accountability for yet
- Your unsolved tickets. All of your tickets that you are actively working on.
- All unsolved tickets. All tickets from across the entire team that everyone is actively working on.
- Recently solved tickets. All tickets that have been moved to solved status (tickets only stay in this status for 16 business hours and then they move to closed). When in a solved state, if customers reply this ticket re-opens. If in a closed state and the customer replies, a new ticket is created.
- Rated tickets from the last 7 days. All tickets from the last 7 days where a customer has taken time to tell us how we did.
- All on-hold tickets. All tickets from across the entire team that are on-hold waiting for a bug fix.
- All closed tickets. All tickets from across the entire team that are closed.
- Suspended tickets. Anything Zendesk deems is spam.
- Deleted tickets. Any deleted tickets.
There are also views for suspended (spam) and deleted tickets. We occasionally check these and never permanently delete anything without a double check with the team just to be sure.
Ticket data fields
When you close a ticket, these are the required fields you must populate:
- Did I make a Task for the doc update needed for this issue? Designates how many updates we are making so we can demonstrated our contributions to improve our docs.
- Have you written a case summary? Holds the team accountable for populating the resolved case database
- Have you uploaded the summary to the GitHub repository? Holds the team accountable for populating the resolved case database
- Official type: Designates whether this is a question, defect report, or help request
- Official priority: Designates whether the priority is p1 or p2 per our definitions outlined in our prioritization guidelines.
- Engineering team: Designates which engineering team is responsible for the part of the product or feature associated with the ticket (think, if I got help/needed help which engineering team did I go to/would have gone to?)
Timezone
Zendesk is set to pacific timezone to align with our states SLAs.
Schedule and SLAs
The schedule in Zendesk reflects our SLA hours and is set to 9–5 pacific, Monday–Friday. This allows us to use the SLA timer to reflect how much time we have before we hit our SLA (if relevant for that customer). The SLA clock is 8 business hours and therefore adds time if a case comes in after hours, on the weekend, or on a holiday. Currently we mark the following as holidays in Zendesk:
- December 24–25 for Christmas
- January 1 for New Year
Since we are global team, we do not add every holiday that everyone celebrates. We only add the holidays where the majority/all of the team is unavailable.
We do not use the SLA function in Zendesk since it doesn’t work with our Slack integration in an optimal way for the team (the team found the never ending counter stressful).
Default to private/internal notes
We have Zendesk set to default to private/internal notes. Since much of our work happens in Slack and we only use internal notes, this ensures we are not sending out-of-context emails by forgetting to change the toggle.
Automations
We have a few automations set-up to streamline our workflow:
- When you reply to a ticket, it auto-assigns to you, so you don’t have to worry about remembering to click “take it” to assign it to yourself
- The signature is built-in and is your name followed by Sourcegraph Support in the second line
- When triage sets the requestor and they are part of an organization where we have an assigned support engineer, the support engineer is automatically assigned via a trigger and their back-up (if there is one) is added as a follower via the same trigger; there is one trigger for each such customer (the list of which can be found in our customer exceptions page.
- Per our customer exceptions page, we have a few customers who have access to Zendesk and they can close their own tickets. When this happens, they are able to bypass the required fields where we gather data. To ensure proper data collection, we have an email notification that is sent to the support engineer responsible for the ticket that the customer has closed the ticket and to please go back to it and fill in the required data fields.
Apps
We use the following apps to streamline our workflow:
- Notes allows us to reflect whatever is in our Exceptions for Customers document in the right panel, as well as anything about this customer’s environment that is useful for troubleshooting
- CC Quest allows us to swap the requester for anyone in CC, which is especially relevant when a CE or SDR copies in support@ and we want to replace their names as the requestor with that of the customer
The customer experience
- When a customer emails support@ they receive an automated email that says: This is an automated email to let you know that the email you just sent to support@sourcegraph.com has been received and if you need it, the ID number is ({{ticket.id}}). We do not count this as our first response (we only send this so you can have peace of mind that your email arrived to us). For our first reply, we aim to be truly helpful, where we have already spent time digging in. This usually happens in a couple of hours. You can read more about how we approach helping you here. If you think of anything else while you wait for us to get back to you with a thoughtful and useful first response, just reply to this email.” Note: this email does not go to folks initiating help requests in our #support- and #trial- Slack channels.
- Once we (and the customer) deem the case solved, we mark the case solved. After an hour of doing so, Zendesk automatically emails a request for feedback on whether the support experience was good or bad. Note: this email does not go to folks initiating help requests in our #support- and #trial- Slack channels.
https://sourcegraph.zendesk.com/
This page is only open for customers who want to login into Zendesk to see all support requests for their organization.
Any user can create an account using their email. By default only tickets that they’ve created or be cc’d on will be visible. There is an option to allow specific users to view all tickets in their org. If this is needed, please ping @cs-leadership or a Zendesk admin to make this change.
Guide customizations
We do not use guide for our documentation, but must have it activated so customers can login into Zendesk as noted in our Exceptions for Customers document. In order to provide an optimal experience, we have made the following customizations:
- Removed search bar
- Modified text on home page
- Modified error messages