Readonly access to Linear issues for users without a Linear account.
This app is designed to enable 'readonly' user access to Linear issues via the Django admin site.
We replaced our use of Jira with Linear a while back, and haven't looked back. However, one thing that would improve it for our use case (small dev / design team, with many engaged internal stakeholders) would be the ability to share the status of issues more widely through the company.
This doesn't need to be sophisticated, we don't need to accept edits / comments - it's just a status update - for any issue, who is working on it, what its status is, which cycle / project it is part of.
The existing Google Sheets integration is almost good enough - but having the data in Django means we can build additional functionality on top (custom notifications, alerts, reporting, etc.)
That said - this project is mainly an excuse to explore the GraphQL API.
We have a large "backoffice" project written in Django, and all our internal staff have accounts set up, and know their way around the Django admin site. Linear has a GraphQL API. Putting these two together, it ought to be simple to sync Linear updates to a Django model, and to surface those via the admin site.
- Access is managed via existing Django authentication
- Data is readonly - if someone needs to edit an issue they should use Linear
- Users who require access to Linear should have a full ($) account
NB this is not a tool to bypass Linear fees. Please respect their hard work.
The integration between Linear and the app occurs in two ways - via bulk import, and via webhook. The data is readonly, so the principal is that all issues are imported once from Linear, and then maintained via the webhook whenever they are updated. The webhook handler will pick up new Issues created after the import.
The integration doesn't go too deep into the data - we store the basics only - this is only intended for use as simple dashboard for people who don't have / need access to Linear itself.
You can import the issues via the admin site itself (there is no "Add Linear issue" button), or if
you wish you can run the import_issues
management command. If you don't have too many issues you
could even run the import on a schedule - start afresh each day.
It's a standard Django app, so add it to INSTALLED_APPS
as you would any other. The webhook URL is
/webook/
, so the recommended configuration is to add it to your main urls.py
like this, making
the full url /linear/webhook/
:
urlpatterns = [
path("linear/", include("linear.urls")),
]
You should use this URL (with your fully-qualified domain name) when adding the webhook to Linear.
The following Django settings are available:
LINEAR_API_KEY
The only setting that is required is a valid API key, which is available from the Linear app, under "Workspace settings" > "API" > "Personal API keys".
LINEAR_API_PAGE_SIZE
The page size to use when importing issues - defaults to 100, the max allowed by the API is 250.
LINEAR_WORKSPACE_NAME
Your workspace name is optional, but it is used in the admin site to provide a link from the object page to Linear - overriding the Django "View on site" link.
There are a couple of other features we have working elsewhere that we are looking to roll into this project:
- Inbound email integration (create issues from emails - for public feedback) (see #1)
- Non-linear user dashboards - ability to subscribe to issues and see progress
This project also contains everything it needs to be deployed directly to Heroku.