GitHub
This page contains the setup guide and reference information for the GitHub source connector.
Prerequisites
- List of GitHub Repositories (and access for them in case they are private)
For Airbyte Cloud:
- OAuth
- Personal Access Token (see Permissions and scopes)
For Airbyte Open Source:
- Personal Access Token (see Permissions and scopes)
Setup guide
Step 1: Set up GitHub
Create a GitHub Account.
Airbyte Open Source additional setup steps
Log into GitHub and then generate a personal access token. To load balance your API quota consumption across multiple API tokens, input multiple tokens separated with ,.
Step 2: Set up the GitHub connector in Airbyte
For Airbyte Cloud:
- Log into your Airbyte Cloud account.
- In the left navigation bar, click Sources.
- On the source selection page, select GitHub from the list of Sources.
- Add a name for your GitHub connector.
- To authenticate:
- For Airbyte Cloud: Authenticate your GitHub account to authorize your GitHub account. Airbyte will authenticate the GitHub account you are already logged in to. Please make sure you are logged into the right account.
- For Airbyte Open Source: Authenticate with Personal Access Token. To generate a personal access token, log into GitHub and then generate a personal access token. Enter your GitHub personal access token. To load balance your API quota consumption across multiple API tokens, input multiple tokens separated with ,.
- GitHub Repositories - Enter a list of GitHub organizations/repositories, e.g. airbytehq/airbytefor single repository,airbytehq/airbyte airbytehq/another-repofor multiple repositories. If you want to specify the organization to receive data from all its repositories, then you should specify it according to the following example:airbytehq/*.
Repositories with the wrong name or repositories that do not exist or have the wrong name format will be skipped with WARN message in the logs.
- Start date (Optional) - The date from which you'd like to replicate data for streams. For streams which support this configuration, only data generated on or after the start date will be replicated.
- 
These streams will only sync records generated on or after the Start Date: comments,commit_comment_reactions,commit_comments,commits,deployments,events,issue_comment_reactions,issue_events,issue_milestones,issue_reactions,issues,project_cards,project_columns,projects,pull_request_comment_reactions,pull_requests,pull_requeststats,releases,review_comments,reviews,stargazers,workflow_runs,workflows.
- 
The Start Date does not apply to the streams below and all data will be synced for these streams: assignees,branches,collaborators,issue_labels,organizations,pull_request_commits,pull_request_stats,repositories,tags,teams,users
- Branch (Optional) - List of GitHub repository branches to pull commits from, e.g. airbytehq/airbyte/master. If no branches are specified for a repository, the default branch will be pulled. (e.g.airbytehq/airbyte/master airbytehq/airbyte/my-branch).
- Max requests per hour (Optional) - The GitHub API allows for a maximum of 5,000 requests per hour (15,000 for Github Enterprise). You can specify a lower value to limit your use of the API quota. Refer to GitHub article Rate limits for the REST API.
Supported sync modes
The GitHub source connector supports the following sync modes:
- Full Refresh - Overwrite
- Full Refresh - Append
- Incremental Sync - Append
- Incremental Sync - Append + Deduped
Supported Streams
This connector outputs the following full refresh streams:
- Assignees
- Branches
- Contributor Activity
- Collaborators
- Issue labels
- Organizations
- Pull request commits
- Tags
- TeamMembers
- TeamMemberships
- Teams
- Users
- Issue timeline events
This connector outputs the following incremental streams:
- Comments
- Commit comment reactions
- Commit comments
- Commits
- Deployments
- Events
- Issue comment reactions
- Issue events
- Issue milestones
- Issue reactions
- Issues
- Project (Classic) cards
- Project (Classic) columns
- Projects (Classic)
- ProjectsV2
- Pull request comment reactions
- Pull request stats
- Pull requests
- Releases
- Repositories
- Review comments
- Reviews
- Stargazers
- WorkflowJobs
- WorkflowRuns
- Workflows
Notes
- 
Only 4 streams ( comments,commits,issuesandreview comments) from the listed above streams are pure incremental meaning that they:- read only new records;
- output only new records.
 
- 
Streams workflow_runsandworflow_jobsis almost pure incremental:
- 
Other 19 incremental streams are also incremental but with one difference, they: - read all records;
- output only new records. Please, consider this behaviour when using those 19 incremental streams because it may affect you API call limits.
 
- 
Sometimes for large streams specifying very distant start_datein the past may result in keep on getting error from GitHub instead of records (respectiveWARNlog message will be outputted). In this case Specifying more recentstart_datemay help. The "Start date" configuration option does not apply to the streams below, because the GitHub API does not include dates which can be used for filtering:
- assignees
- branches
- collaborators
- issue_labels
- organizations
- pull_request_commits
- pull_request_stats
- repositories
- tags
- teams
- users
Limitations & Troubleshooting
Expand to see details about GitHub connector limitations and troubleshooting.
Connector limitations
Rate limiting
You can use a personal access token to make API requests. Additionally, you can authorize a GitHub App or OAuth app, which can then make API requests on your behalf. All of these requests count towards your personal rate limit of 5,000 requests per hour (15,000 requests per hour if the app is owned by a GitHub Enterprise Cloud organization ).
REST API and GraphQL API rate limits are counted separatelyIn the event that limits are reached before all streams have been read, it is recommended to take the following actions:
- Utilize Incremental sync mode.
- Set a higher sync interval.
- Divide the sync into separate connections with a smaller number of streams.
Refer to GitHub article Rate limits for the REST API.
Permissions and scopes
If you use OAuth authentication method, the OAuth2.0 application requests the next list of scopes: repo, read:org, read:repo_hook, read:user, read:discussion, read:project, workflow. For personal access token you need to manually select needed scopes.
Your token should have at least the repo scope. Depending on which streams you want to sync, the user generating the token needs more permissions:
- For syncing Collaborators, the user which generates the personal access token must be a collaborator. To become a collaborator, they must be invited by an owner. If there are no collaborators, no records will be synced. Read more about access permissions here.
- Syncing Teams is only available to authenticated members of a team's organization. Personal user accounts and repositories belonging to them don't have access to Teams features. In this case no records will be synced.
- To sync the Projects stream, the repository must have the Projects feature enabled.
Troubleshooting
- Check out common troubleshooting issues for the GitHub source connector on our Airbyte Forum
Reference
Config fields reference
Changelog
| Version | Date | Pull Request | Subject | 
|---|---|---|---|
| 1.6.3 | 2024-02-15 | 35271 | Update branches schema | 
| 1.6.2 | 2024-02-12 | 34933 | Update Airbyte CDK for integration tests | 
| 1.6.1 | 2024-02-09 | 35087 | Manage dependencies with Poetry. | 
| 1.6.0 | 2024-02-02 | 34700 | Continue Sync on Stream failure | 
| 1.5.7 | 2024-01-29 | 34598 | Fix MultipleToken sleep time | 
| 1.5.6 | 2024-01-26 | 34503 | Fix MultipleToken rotation logic | 
| 1.5.5 | 2023-12-26 | 33783 | Fix retry for 504 error in GraphQL based streams | 
| 1.5.4 | 2023-11-20 | 32679 | Return AirbyteMessage if max retry exeeded for 202 status code | 
| 1.5.3 | 2023-10-23 | 31702 | Base image migration: remove Dockerfile and use the python-connector-base image | 
| 1.5.2 | 2023-10-13 | 31386 | Handle ContributorActivitycontinuousACCEPTEDresponse | 
| 1.5.1 | 2023-10-12 | 31307 | Increase backoff_time for stream ContributorActivity | 
| 1.5.0 | 2023-10-11 | 31300 | Update Schemas: Add date-time format to fields | 
| 1.4.6 | 2023-10-04 | 31056 | Migrate spec properties' repositoryandbranchtype to <array> | 
| 1.4.5 | 2023-10-02 | 31023 | Increase backoff for stream Contributor Activity | 
| 1.4.4 | 2023-10-02 | 30971 | Mark start_dateas optional. | 
| 1.4.3 | 2023-10-02 | 30979 | Fetch archived records in Project Cards | 
| 1.4.2 | 2023-09-30 | 30927 | Provide actionable user error messages | 
| 1.4.1 | 2023-09-30 | 30839 | Update CDK to Latest version | 
| 1.4.0 | 2023-09-29 | 30823 | Add new stream issue Timeline Events | 
| 1.3.1 | 2023-09-28 | 30824 | Handle empty response in stream ContributorActivity | 
| 1.3.0 | 2023-09-25 | 30731 | Add new stream ProjectsV2 | 
| 1.2.1 | 2023-09-22 | 30693 | Handle 404 error in TeamMemberShips | 
| 1.2.0 | 2023-09-22 | 30647 | Add support for self-hosted GitHub instances | 
| 1.1.1 | 2023-09-21 | 30654 | Rewrite source connection error messages | 
| 1.1.0 | 2023-08-03 | 30615 | Add new stream Contributor Activity | 
| 1.0.4 | 2023-08-03 | 29031 | Reverted advancedAuthspec changes | 
| 1.0.3 | 2023-08-01 | 28910 | Updated advancedAuthbroken references | 
| 1.0.2 | 2023-07-11 | 28144 | Add archived_atproperty toOrganizationsschema parameter | 
| 1.0.1 | 2023-05-22 | 25838 | Deprecate "page size" input parameter | 
| 1.0.0 | 2023-05-19 | 25778 | Improve repo(s) name validation on UI | 
| 0.5.0 | 2023-05-16 | 25793 | Implement client-side throttling of requests | 
| 0.4.11 | 2023-05-12 | 26025 | Added more transparent depiction of the personal access token expired | 
| 0.4.10 | 2023-05-15 | 26075 | Add more specific error message description for no repos case. | 
| 0.4.9 | 2023-05-01 | 24523 | Add undeclared columns to spec | 
| 0.4.8 | 2023-04-19 | 00000 | Fix repo name validation | 
| 0.4.7 | 2023-03-24 | 24457 | Add validation and transformation for repositories config | 
| 0.4.6 | 2023-03-24 | 24398 | Fix caching for get_starting_pointin stream "Commits" | 
| 0.4.5 | 2023-03-23 | 24417 | Add pattern_descriptors to fields with an expected format | 
| 0.4.4 | 2023-03-17 | 24255 | Add field groups and titles to improve display of connector setup form | 
| 0.4.3 | 2023-03-04 | 22993 | Specified date formatting in specification | 
| 0.4.2 | 2023-03-03 | 23467 | added user friendly messages, added AirbyteTracedException config_error, updated SAT | 
| 0.4.1 | 2023-01-27 | 22039 | Set AvailabilityStrategyfor streams explicitly toNone | 
| 0.4.0 | 2023-01-20 | 21457 | Use GraphQL for issue_reactionsstream | 
| 0.3.12 | 2023-01-18 | 21481 | Handle 502 Bad Gateway error with proper log message | 
| 0.3.11 | 2023-01-06 | 21084 | Raise Error if no organizations or repos are available during read | 
| 0.3.10 | 2022-12-15 | 20523 | Revert changes from 0.3.9 | 
| 0.3.9 | 2022-12-14 | 19978 | Update CDK dependency; move custom HTTPError handling into AvailabilityStrategyclasses | 
| 0.3.8 | 2022-11-10 | 19299 | Fix events and workflow_runs datetimes | 
| 0.3.7 | 2022-10-20 | 18213 | Skip retry on HTTP 200 | 
| 0.3.6 | 2022-10-11 | 17852 | Use default behaviour, retry on 429 and all 5XX errors | 
| 0.3.5 | 2022-10-07 | 17715 | Improve 502 handling for commentsstream | 
| 0.3.4 | 2022-10-04 | 17555 | Skip repository if got HTTP 500 for WorkflowRuns stream | 
| 0.3.3 | 2022-09-28 | 17287 | Fix problem with "null" cursor_fieldfor WorkflowJobs stream | 
| 0.3.2 | 2022-09-28 | 17304 | Migrate to per-stream state. | 
| 0.3.1 | 2022-09-21 | 16947 | Improve error logging when handling HTTP 500 error | 
| 0.3.0 | 2022-09-09 | 16534 | Add new stream WorkflowJobs | 
| 0.2.46 | 2022-08-17 | 15730 | Validate input organizations and repositories | 
| 0.2.45 | 2022-08-11 | 15420 | "User" object can be "null" | 
| 0.2.44 | 2022-08-01 | 14795 | Use GraphQL for pull_request_comment_reactionsstream | 
| 0.2.43 | 2022-07-26 | 15049 | Bugfix schemas for streams deployments,workflow_runs,teams | 
| 0.2.42 | 2022-07-12 | 14613 | Improve schema for stream pull_request_commitsadded "null" | 
| 0.2.41 | 2022-07-03 | 14376 | Add Retry for GraphQL API Resource limitations | 
| 0.2.40 | 2022-07-01 | 14338 | Revert: "Rename field mergeabletois_mergeable" | 
| 0.2.39 | 2022-06-30 | 14274 | Rename field mergeabletois_mergeable | 
| 0.2.38 | 2022-06-27 | 13989 | Use GraphQL for reviewsstream | 
| 0.2.37 | 2022-06-21 | 13955 | Fix "secondary rate limit" not retrying | 
| 0.2.36 | 2022-06-20 | 13926 | Break point added for workflows_runsstream | 
| 0.2.35 | 2022-06-16 | 13763 | Use GraphQL for pull_request_statsstream | 
| 0.2.34 | 2022-06-14 | 13707 | Fix API sorting, fix get_starting_pointcaching | 
| 0.2.33 | 2022-06-08 | 13558 | Enable caching only for parent streams | 
| 0.2.32 | 2022-06-07 | 13531 | Fix different result from get_starting_pointwhen reading by pages | 
| 0.2.31 | 2022-05-24 | 13115 | Add incremental support for streams WorkflowRuns | 
| 0.2.30 | 2022-05-09 | 12294 | Add incremental support for streams CommitCommentReactions,IssueCommentReactions,IssueReactions,PullRequestCommentReactions,Repositories,Workflows | 
| 0.2.29 | 2022-05-04 | 12482 | Update input configuration copy | 
| 0.2.28 | 2022-04-21 | 11893 | Add new streams TeamMembers,TeamMemberships | 
| 0.2.27 | 2022-04-02 | 11678 | Fix "PAT Credentials" in spec | 
| 0.2.26 | 2022-03-31 | 11623 | Re-factored incremental sync for Reviewsstream | 
| 0.2.25 | 2022-03-31 | 11567 | Improve code for better error handling | 
| 0.2.24 | 2022-03-30 | 9251 | Add Streams Workflow and WorkflowRuns | 
| 0.2.23 | 2022-03-17 | 11212 | Improve documentation and spec for Beta | 
| 0.2.22 | 2022-03-10 | 10878 | Fix error handling for unavailable streams with 404 status code | 
| 0.2.21 | 2022-03-04 | 10749 | Add new stream ProjectCards | 
| 0.2.20 | 2022-02-16 | 10385 | Add new stream Deployments,ProjectColumns,PullRequestCommits | 
| 0.2.19 | 2022-02-07 | 10211 | Add human-readable error in case of incorrect organization or repo name | 
| 0.2.18 | 2021-02-09 | 10193 | Add handling secondary rate limits | 
| 0.2.17 | 2021-02-02 | 9999 | Remove BAD_GATEWAY code from backoff_time | 
| 0.2.16 | 2021-02-02 | 9868 | Add log message for streams that are restricted for OAuth. Update oauth scopes. | 
| 0.2.15 | 2021-01-26 | 9802 | Add missing fields for auto_merge in pull request stream | 
| 0.2.14 | 2021-01-21 | 9664 | Add custom pagination size for large streams | 
| 0.2.13 | 2021-01-20 | 9619 | Fix logging for function should_retry | 
| 0.2.11 | 2021-01-17 | 9492 | Remove optional parameter Acceptfor reaction`s streams to fix error with 502 HTTP status code in response | 
| 0.2.10 | 2021-01-03 | 7250 | Use CDK caching and convert PR-related streams to incremental | 
| 0.2.9 | 2021-12-29 | 9179 | Use default retry delays on server error responses | 
| 0.2.8 | 2021-12-07 | 8524 | Update connector fields title/description | 
| 0.2.7 | 2021-12-06 | 8518 | Add connection retry with GitHub | 
| 0.2.6 | 2021-11-24 | 8030 | Support start date property for PullRequestStats and Reviews streams | 
| 0.2.5 | 2021-11-21 | 8170 | Fix slow check connection for organizations with a lot of repos | 
| 0.2.4 | 2021-11-11 | 7856 | Resolve $ref fields in some stream schemas | 
| 0.2.3 | 2021-10-06 | 6833 | Fix config backward compatability | 
| 0.2.2 | 2021-10-05 | 6761 | Add oauth worflow specification | 
| 0.2.1 | 2021-09-22 | 6223 | Add option to pull commits from user-specified branches | 
| 0.2.0 | 2021-09-19 | 5898 and 6227 | Don't minimize any output fields & add better error handling | 
| 0.1.11 | 2021-09-15 | 5949 | Add caching for all streams | 
| 0.1.10 | 2021-09-09 | 5860 | Add reaction streams | 
| 0.1.9 | 2021-09-02 | 5788 | Handling empty repository, check method using RepositoryStats stream | 
| 0.1.8 | 2021-09-01 | 5757 | Add more streams | 
| 0.1.7 | 2021-08-27 | 5696 | Handle negative backoff values | 
| 0.1.6 | 2021-08-18 | 5456 | Add MultipleTokenAuthenticator | 
| 0.1.5 | 2021-08-18 | 5456 | Fix set up validation | 
| 0.1.4 | 2021-08-13 | 5136 | Support syncing multiple repositories/organizations | 
| 0.1.3 | 2021-08-03 | 5156 | Extended existing schemas with usersproperty for certain streams | 
| 0.1.2 | 2021-07-13 | 4708 | Fix bug with IssueEvents stream and add handling for rate limiting | 
| 0.1.1 | 2021-07-07 | 4590 | Fix schema in the pull_requeststream | 
| 0.1.0 | 2021-07-06 | 4174 | New Source: GitHub |