GitHub API Configuration
Request
POST https://api.fivetran.com/v1/connections
{
  "group_id": "group_id",
  "service": "github",
  "trust_certificates": true,
  "trust_fingerprints": true,
  "run_setup_tests": true,
  "paused": false,
  "pause_after_trial": false,
  "sync_frequency": 1440,
  "data_delay_sensitivity": "NORMAL",
  "data_delay_threshold": 0,
  "daily_sync_time": "14:00",
  "schedule_type": "auto",
  "connect_card_config": {
    "redirect_uri": "https://your.site/path",
    "hide_setup_guide": true
  },
  "proxy_agent_id": "proxy_agent_id",
  "private_link_id": "private_link_id",
  "networking_method": "Directly",
  "hybrid_deployment_agent_id": "hybrid_deployment_agent_id",
  "destination_configuration": {
    "virtual_warehouse": "virtual_warehouse"
  },
  "config": {
    "sync_mode": "SpecificRepositories | AllRepositories",
    "use_webhooks": true,
    "pats": [
      "string"
    ],
    "repositories": [
      "string"
    ],
    "auth_mode": "JWT | PersonalAccessToken | OAuth",
    "username": "string",
    "schema": "schema_name"
  }
}Config parameters
| Name | Description | 
|---|---|
| sync_mode | Whether to sync all repositories or specific repositories. | 
| use_webhooks | Set to trueto capture deletes. | 
| pats | The Personal Access Tokens. | 
| repositories | Specific Repository IDs to sync. Must be populated if syncModeis set toSpecificRepositories. | 
| auth_mode | Authorization type. | 
| username | Loginof your GitHub profile. | 
| schema(required) | Destination schema name. Schema name is permanent and cannot be changed after connection creation | 
Authorization
There are two ways to authorize this connector type:
- Personal Access Tokens: By specifying the auth_modeas"PersonalAccessToken"and the value for thepatsparameter in the request.POST https://api.fivetran.com/v1/connections{ "service": "github", "group_id": "group_id", "config": { "pats": [ "string" ], "auth_mode": "PersonalAccessToken" } }
- By using the Connect Card or the Fivetran dashboard.