JQL client with TS support
Hi there!
Lately I’ve been trying to automate some tedious parts of the release process at my job. Long story short we must verify that all commits point to right Jira issue and the release version matches.
To my surprise I couldn’t find existing JQL client library so I wrote my own and the best part is that it’s fully typed!
Problem
There’s a Jira REST API available that allows you to fetch issues with quite
sophisticated query language called JQL. For example, we can fetch all the
issues for a given list of keys (you can think of issue key as an alternative
way to identify an issue, sort of like an ID) and ask only for a subset of
fields, say "summary" and "description". The query would look like this:
ts
ts
and the result:
ts
ts
Given how flexible the query can be, we would like to reflect what fields are available in the resulting type, so that accessing fields we didn’t explicitly asked for would throw a type error.
So let’s get to work!
Code
First, let’s create the Issue and all the accompanying types. The tricky part
is that the resulting type depends on the constructed query. Generics to the
rescue!
We’ll create two type parameters E, a union of on-demand extends and F, a
union of field names to filter. Then we’ll pass these two type variables starting from
the client query() method where they will be inferred from the arguments passed by
the developer and forward them down to the final Issue type.
ts
ts
now let’s take care of the JQL request:
ts
ts
and the response:
ts
ts
now having all types in place let’s assemble the client:
ts
ts
Usage example
Now I can perform JQL requests, specify what ‘on-demand’ extends or fields I want with full type support 🎉
ts
ts
Here are the types I didn’t include to make the code easier to read:
ts
ts
Summary
The next step? Type JQLRequest["jql"] to only allow valid queries, and make a
proper library out of it, but that’s a topic for another blog post.
Until next time!