Skip to content

Commit

Permalink
fix auth to use api token and user email (#86)
Browse files Browse the repository at this point in the history
  • Loading branch information
pnadolny13 authored Oct 17, 2024
1 parent 8c77322 commit ca4fe87
Show file tree
Hide file tree
Showing 5 changed files with 61 additions and 102 deletions.
70 changes: 30 additions & 40 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
# tap-jira

`tap-jira` is a Singer tap for tap-jira.
# `tap-jira`

Built with the [Meltano Tap SDK](https://sdk.meltano.com) for Singer Taps.
tap-jira tap class.

Built with the [Meltano Singer SDK](https://sdk.meltano.com).

## Capabilities

Expand All @@ -12,42 +12,32 @@ Built with the [Meltano Tap SDK](https://sdk.meltano.com) for Singer Taps.
* `about`
* `stream-maps`
* `schema-flattening`

## Configuration

### Accepted Config Options

| Setting | Required | Default | Description |
|:--------------------|:--------:|:-------:|:--------------------------------------------------------------------------------------------------------------------------------------------|
| start_date | False | None | Earliest record date to sync |
| end_date | False | None | Latest record date to sync |
| auth | True | None | Auth type for Jira API requires either access_token or username/password |
| domain | True | None | Site URL |
| stream_maps | False | None | Config object for stream maps capability. For more information check out [Stream Maps](https://sdk.meltano.com/en/latest/stream_maps.html). |
| stream_map_config | False | None | User-defined config values to be used within map expressions. |
| flattening_enabled | False | None | 'True' to enable schema flattening and automatically expand nested properties. |
| flattening_max_depth| False | None | The max depth to flatten schemas. |

The auth setting works either with access token or username/password, set by the following configs:

Auth with access token:
```bash
TAP_JIRA_AUTH_FLOW = 'oauth'
TAP_JIRA_AUTH_ACCESS_TOKEN = ''
```

Auth with username/password:
```bash
TAP_JIRA_AUTH_FLOW = 'password'
TAP_JIRA_AUTH_USERNAME = ''
TAP_JIRA_AUTH_PASSWORD = ''
```

A full list of supported settings and capabilities for this tap is available by running:

```bash
tap-jira --about
```
* `batch`

## Settings

| Setting | Required | Default | Description |
|:--------------------|:--------:|:-------:|:------------|
| start_date | False | None | Earliest record date to sync |
| end_date | False | None | Latest record date to sync |
| domain | True | None | The Domain for your Jira account, e.g. meltano.atlassian.net |
| api_token | True | None | Jira API Token. |
| Email | True | None | The user email for your Jira account. |
| page_size | False | None | |
| stream_maps | False | None | Config object for stream maps capability. For more information check out [Stream Maps](https://sdk.meltano.com/en/latest/stream_maps.html). |
| stream_map_config | False | None | User-defined config values to be used within map expressions. |
| flattening_enabled | False | None | 'True' to enable schema flattening and automatically expand nested properties. |
| flattening_max_depth| False | None | The max depth to flatten schemas. |
| batch_config | False | None | |

A full list of supported settings and capabilities is available by running: `tap-jira --about`

## Supported Python Versions

* 3.8
* 3.9
* 3.10
* 3.11

## Elastic License 2.0

Expand Down
7 changes: 7 additions & 0 deletions tap_jira/__main__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
"""Jira entry point."""

from __future__ import annotations

from tap_jira.tap import TapJira

TapJira.cli()
24 changes: 7 additions & 17 deletions tap_jira/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,10 @@
from __future__ import annotations

from pathlib import Path
from typing import Any, Callable, Iterable
from typing import Any, Callable

import requests
from singer_sdk.authenticators import BasicAuthenticator, BearerTokenAuthenticator
from singer_sdk.helpers.jsonpath import extract_jsonpath
from singer_sdk.pagination import BaseAPIPaginator
from singer_sdk.authenticators import BasicAuthenticator
from singer_sdk.streams import RESTStream

_Auth = Callable[[requests.PreparedRequest], requests.PreparedRequest]
Expand Down Expand Up @@ -43,19 +41,11 @@ def authenticator(self) -> _Auth:
Returns:
An authenticator instance.
"""
auth_type = self.config["auth"]["flow"]

if auth_type == "oauth":
return BearerTokenAuthenticator.create_for_stream(
self,
token=self.config["auth"]["access_token"],
)
else:
return BasicAuthenticator.create_for_stream(
self,
password=self.config["auth"]["password"],
username=self.config["auth"]["username"],
)
return BasicAuthenticator.create_for_stream(
self,
password=self.config["api_token"],
username=self.config["email"],
)

@property
def http_headers(self) -> dict:
Expand Down
29 changes: 1 addition & 28 deletions tap_jira/streams.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,11 @@
from pathlib import Path
from typing import Optional

import requests
from singer_sdk import typing as th # JSON Schema typing helpers

from tap_jira.client import JiraStream

import requests

PropertiesList = th.PropertiesList
Property = th.Property
ObjectType = th.ObjectType
Expand All @@ -25,7 +24,6 @@


class UsersStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-users/#api-rest-api-3-user-get
"""
Expand Down Expand Up @@ -89,7 +87,6 @@ def get_next_page_token(


class FieldStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-issue-fields/#api-rest-api-3-field-get
"""
Expand Down Expand Up @@ -158,7 +155,6 @@ class FieldStream(JiraStream):


class ServerInfoStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-server-info/#api-rest-api-3-serverinfo-get
"""
Expand Down Expand Up @@ -198,7 +194,6 @@ class ServerInfoStream(JiraStream):


class IssueTypeStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-issue-types/#api-rest-api-3-issuetype-get
"""
Expand Down Expand Up @@ -248,7 +243,6 @@ class IssueTypeStream(JiraStream):


class WorkflowStatusStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-workflow-statuses/#api-rest-api-3-status-get
"""
Expand Down Expand Up @@ -301,7 +295,6 @@ class WorkflowStatusStream(JiraStream):


class ProjectStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-projects/#api-rest-api-3-project-get
"""
Expand Down Expand Up @@ -370,7 +363,6 @@ class ProjectStream(JiraStream):


class IssueStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-issue-search/#api-rest-api-3-search-get
"""
Expand Down Expand Up @@ -2350,7 +2342,6 @@ def post_process(self, row: dict, context: dict | None = None) -> dict | None:


class PermissionStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-permissions/#api-rest-api-3-permissions-get
"""
Expand Down Expand Up @@ -2776,7 +2767,6 @@ class PermissionStream(JiraStream):


class ProjectRoleStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-project-roles/#api-rest-api-3-role-get
"""
Expand Down Expand Up @@ -2842,7 +2832,6 @@ class ProjectRoleStream(JiraStream):


class PriorityStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-issue-priorities/#api-rest-api-3-priority-get
"""
Expand Down Expand Up @@ -2873,7 +2862,6 @@ class PriorityStream(JiraStream):


class PermissionHolderStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-permission-schemes/#api-rest-api-3-permissionscheme-get
"""
Expand Down Expand Up @@ -3041,7 +3029,6 @@ def get_records(self, context: dict | None) -> Iterable[dict[str, Any]]:


class ProjectRoleActorStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-project-role-actors/#api-rest-api-3-role-id-actors-get
"""
Expand Down Expand Up @@ -3143,7 +3130,6 @@ class ProjectRoleActor(JiraStream):


class AuditingStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-audit-records/#api-rest-api-3-auditing-record-get
"""
Expand Down Expand Up @@ -3210,7 +3196,6 @@ class AuditingStream(JiraStream):


class DashboardStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-dashboards/#api-rest-api-3-dashboard-get
"""
Expand Down Expand Up @@ -3260,7 +3245,6 @@ class DashboardStream(JiraStream):


class FilterSearchStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-filters/#api-rest-api-3-filter-search-get
"""
Expand Down Expand Up @@ -3291,7 +3275,6 @@ class FilterSearchStream(JiraStream):


class FilterDefaultShareScopeStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-filter-sharing/#api-rest-api-3-filter-defaultsharescope-get
"""
Expand All @@ -3317,7 +3300,6 @@ class FilterDefaultShareScopeStream(JiraStream):


class GroupsPickerStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-groups/#api-rest-api-3-groups-picker-get
"""
Expand Down Expand Up @@ -3357,7 +3339,6 @@ class GroupsPickerStream(JiraStream):


class LicenseStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-license-metrics/#api-rest-api-3-instance-license-get
"""
Expand Down Expand Up @@ -3386,7 +3367,6 @@ class LicenseStream(JiraStream):


class ScreensStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-screens/#api-rest-api-3-screens-get
"""
Expand Down Expand Up @@ -3428,7 +3408,6 @@ class ScreensStream(JiraStream):


class ScreenSchemesStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-screen-tab-fields/#api-rest-api-3-screens-screenid-tabs-tabid-fields-get
"""
Expand Down Expand Up @@ -3464,7 +3443,6 @@ class ScreenSchemesStream(JiraStream):


class StatusesSearchStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-screen-tab-fields/#api-rest-api-3-screens-screenid-tabs-tabid-fields-get
"""
Expand Down Expand Up @@ -3501,7 +3479,6 @@ class StatusesSearchStream(JiraStream):


class WorkflowStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-workflows/#api-rest-api-3-workflow-get
"""
Expand Down Expand Up @@ -3577,7 +3554,6 @@ class Resolutions(JiraStream):


class WorkflowSearchStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-workflows/#api-rest-api-3-workflow-get
"""
Expand Down Expand Up @@ -3617,7 +3593,6 @@ class WorkflowSearchStream(JiraStream):


class IssueWatchersStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-workflows/#api-rest-api-3-workflow-get
"""
Expand Down Expand Up @@ -3662,7 +3637,6 @@ def post_process(self, row: dict, context: dict) -> dict:


class IssueChangeLogStream(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-workflows/#api-rest-api-3-workflow-get
"""
Expand Down Expand Up @@ -3721,7 +3695,6 @@ def post_process(self, row: dict, context: dict) -> dict:


class IssueComments(JiraStream):

"""
https://developer.atlassian.com/cloud/jira/platform/rest/v3/api-group-issue-comments/#api-rest-api-3-issue-issueidorkey-comment-get
"""
Expand Down
33 changes: 16 additions & 17 deletions tap_jira/tap.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,31 +27,30 @@ class TapJira(Tap):
th.Property(
"domain",
th.StringType,
description="Site URL",
description="The Domain for your Jira account, e.g. meltano.atlassian.net",
required=True,
),
th.Property(
"auth",
th.DiscriminatedUnion(
"flow",
oauth=th.ObjectType(
th.Property(
"access_token", th.StringType, required=True, secret=True
),
additional_properties=False,
),
password=th.ObjectType(
th.Property("username", th.StringType, required=True),
th.Property("password", th.StringType, required=True, secret=True),
additional_properties=False,
),
),
"api_token",
th.StringType,
description="Jira API Token.",
required=True,
),
th.Property(
"email",
th.StringType,
description="The user email for your Jira account.",
required=True,
),
th.Property(
"page_size",
th.ObjectType(
th.Property("issues", th.IntegerType, description="Page size for issues stream", default=100),
th.Property(
"issues",
th.IntegerType,
description="Page size for issues stream",
default=100,
),
),
),
).to_dict()
Expand Down

0 comments on commit ca4fe87

Please sign in to comment.