-
Notifications
You must be signed in to change notification settings - Fork 211
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Jira Source Configuration and Filter Changes and add license headers #5306
Changes from 4 commits
3e3ad8a
f776d4a
72bc844
a5a4210
66d05ce
d3b4446
e94dcf0
2bf1316
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,16 +1,14 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can you please add the license header. This should be added to all the files. See: https://github.com/opensearch-project/data-prepper/blob/main/CONTRIBUTING.md#license-headers There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. added to all jira source files |
||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.Size; | ||
import jakarta.validation.Valid; | ||
import lombok.Getter; | ||
import org.opensearch.dataprepper.plugins.source.jira.configuration.AuthenticationConfig; | ||
import org.opensearch.dataprepper.plugins.source.jira.configuration.FilterConfig; | ||
import org.opensearch.dataprepper.plugins.source.source_crawler.base.CrawlerSourceConfig; | ||
|
||
import java.time.Duration; | ||
import java.util.ArrayList; | ||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import static org.opensearch.dataprepper.plugins.source.jira.utils.Constants.OAUTH2; | ||
|
||
@Getter | ||
public class JiraSourceConfig implements CrawlerSourceConfig { | ||
|
@@ -20,50 +18,23 @@ public class JiraSourceConfig implements CrawlerSourceConfig { | |
/** | ||
* Jira account url | ||
*/ | ||
@JsonProperty("account_url") | ||
private String accountUrl; | ||
|
||
/** | ||
* A map of connector credentials specific to this source | ||
*/ | ||
@JsonProperty("connector_credentials") | ||
private Map<String, String> connectorCredentials; | ||
|
||
/** | ||
* List of projects to ingest | ||
*/ | ||
@JsonProperty("projects") | ||
@Size(max = 1000, message = "Project type filter should not be more than 1000") | ||
private List<String> project = new ArrayList<>(); | ||
@JsonProperty("hosts") | ||
private List<String> hosts; | ||
|
||
/** | ||
* List of specific issue types to ingest. | ||
* Ex: Story, Epic, Task etc | ||
* Authentication Config to Access Jira | ||
*/ | ||
@JsonProperty("issue_types") | ||
@Size(max = 1000, message = "Issue type filter should be less than 1000") | ||
private List<String> issueType = new ArrayList<>(); | ||
@JsonProperty("authentication") | ||
@Valid | ||
private AuthenticationConfig authenticationConfig; | ||
|
||
/** | ||
* Optional Inclusion patterns for filtering some tickets | ||
*/ | ||
@JsonProperty("inclusion_patterns") | ||
@Size(max = 100, message = "inclusion pattern filters should not be more than 1000") | ||
private List<String> inclusionPatterns; | ||
|
||
/** | ||
* Optional Exclusion patterns for excluding some tickets | ||
* Filter Config to filter what tickets get ingested | ||
*/ | ||
@JsonProperty("exclusion_patterns") | ||
@Size(max = 1000, message = "exclusion pattern filter should be less than 1000") | ||
private List<String> exclusionPatterns; | ||
@JsonProperty("filter") | ||
private FilterConfig filterConfig; | ||
|
||
/** | ||
* Optional Status filter to ingest the tickets | ||
*/ | ||
@JsonProperty("statuses") | ||
@Size(max = 1000, message = "Status filter should be less than 1000") | ||
private List<String> status = new ArrayList<>(); | ||
|
||
/** | ||
* Number of worker threads to spawn to parallel source fetching | ||
|
@@ -78,43 +49,11 @@ public class JiraSourceConfig implements CrawlerSourceConfig { | |
@JsonProperty("backoff_time") | ||
private Duration backOff = DEFAULT_BACKOFF_MILLIS; | ||
|
||
public String getJiraId() { | ||
return this.getConnectorCredentials().get("jira_id"); | ||
} | ||
|
||
public String getJiraCredential() { | ||
return this.getConnectorCredentials().get("jira_credential"); | ||
public String getAccountUrl() { | ||
return this.getHosts().get(0); | ||
} | ||
|
||
public String getAuthType() { | ||
return this.getConnectorCredentials().get("auth_type"); | ||
} | ||
|
||
public String getAccessToken() { | ||
return fetchGivenOAuthAttribute("access_token"); | ||
} | ||
|
||
public String getRefreshToken() { | ||
return fetchGivenOAuthAttribute("refresh_token"); | ||
} | ||
|
||
public String getClientId() { | ||
return fetchGivenOAuthAttribute("client_id"); | ||
} | ||
|
||
public String getClientSecret() { | ||
return fetchGivenOAuthAttribute("client_secret"); | ||
return this.getAuthenticationConfig().getAuthType(); | ||
} | ||
|
||
private String fetchGivenOAuthAttribute(String givenAttribute) { | ||
if (!OAUTH2.equals(getAuthType())) { | ||
throw new RuntimeException("Authentication Type is not OAuth2."); | ||
} | ||
String attributeValue = this.getConnectorCredentials().get(givenAttribute); | ||
if (attributeValue == null || attributeValue.isEmpty()) { | ||
throw new RuntimeException(String.format("%s is required for OAuth2 AuthType", givenAttribute)); | ||
} | ||
return attributeValue; | ||
} | ||
|
||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.Valid; | ||
import jakarta.validation.constraints.AssertTrue; | ||
import lombok.Getter; | ||
|
||
import static org.opensearch.dataprepper.plugins.source.jira.utils.Constants.BASIC; | ||
import static org.opensearch.dataprepper.plugins.source.jira.utils.Constants.OAUTH2; | ||
|
||
@Getter | ||
public class AuthenticationConfig { | ||
@JsonProperty("basic") | ||
@Valid | ||
private BasicConfig basicConfig; | ||
|
||
@JsonProperty("oauth2") | ||
@Valid | ||
private Oauth2Config oauth2Config; | ||
|
||
@AssertTrue(message = "Authentication config should have either basic or oauth2") | ||
private boolean isValidAuthenticationConfig() { | ||
boolean hasBasic = basicConfig != null; | ||
boolean hasOauth = oauth2Config != null; | ||
return hasBasic ^ hasOauth; | ||
} | ||
|
||
public String getAuthType() { | ||
if (basicConfig != null) { | ||
return BASIC; | ||
} else { | ||
return OAUTH2; | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.AssertTrue; | ||
import lombok.Getter; | ||
|
||
@Getter | ||
public class BasicConfig { | ||
@JsonProperty("username") | ||
private String username; | ||
|
||
@JsonProperty("password") | ||
private String password; | ||
|
||
@AssertTrue(message = "Username and Password are both required for Basic Auth") | ||
private boolean isBasicConfigValid() { | ||
return username != null && password != null; | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import lombok.Getter; | ||
|
||
@Getter | ||
public class FilterConfig { | ||
@JsonProperty("project") | ||
private ProjectConfig projectConfig; | ||
|
||
@JsonProperty("status") | ||
private StatusConfig statusConfig; | ||
|
||
@JsonProperty("issue_type") | ||
private IssueTypeConfig issueTypeConfig; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.Size; | ||
import lombok.Getter; | ||
|
||
import java.util.ArrayList; | ||
import java.util.List; | ||
|
||
@Getter | ||
public class IssueTypeConfig { | ||
@JsonProperty("include") | ||
@Size(max = 1000, message = "Issue type filter should not be more than 1000") | ||
private List<String> include = new ArrayList<>(); | ||
|
||
@JsonProperty("exclude") | ||
@Size(max = 1000, message = "Issue type filter should not be more than 1000") | ||
private List<String> exclude = new ArrayList<>(); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.Size; | ||
import lombok.Getter; | ||
|
||
import java.util.ArrayList; | ||
import java.util.List; | ||
|
||
@Getter | ||
public class NameConfig { | ||
@JsonProperty("include") | ||
@Size(max = 1000, message = "Project name type filter should not be more than 1000") | ||
private List<String> include = new ArrayList<>(); | ||
|
||
@JsonProperty("exclude") | ||
@Size(max = 1000, message = "Project name type filter should not be more than 1000") | ||
private List<String> exclude = new ArrayList<>(); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.AssertTrue; | ||
import lombok.Getter; | ||
|
||
@Getter | ||
public class Oauth2Config { | ||
@JsonProperty("client_id") | ||
private String clientId; | ||
|
||
@JsonProperty("client_secret") | ||
private String clientSecret; | ||
|
||
@JsonProperty("access_token") | ||
private String accessToken; | ||
|
||
@JsonProperty("refresh_token") | ||
private String refreshToken; | ||
|
||
@AssertTrue(message = "Client ID, Client Secret, Access Token, and Refresh Token are both required for Oauth2") | ||
private boolean isOauth2ConfigValid() { | ||
return clientId != null && clientSecret != null && accessToken != null && refreshToken != null; | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import lombok.Getter; | ||
|
||
@Getter | ||
public class ProjectConfig { | ||
@JsonProperty("name") | ||
private NameConfig nameConfig; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package org.opensearch.dataprepper.plugins.source.jira.configuration; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import jakarta.validation.constraints.Size; | ||
import lombok.Getter; | ||
|
||
import java.util.ArrayList; | ||
import java.util.List; | ||
|
||
@Getter | ||
public class StatusConfig { | ||
@JsonProperty("include") | ||
@Size(max = 1000, message = "status type filter should not be more than 1000") | ||
private List<String> include = new ArrayList<>(); | ||
|
||
@JsonProperty("exclude") | ||
@Size(max = 1000, message = "status type filter should not be more than 1000") | ||
private List<String> exclude = new ArrayList<>(); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think, you should also add additional validation where a project listed in include is not listed in exclude and vice versa
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will add to validate Project Filters