This is a Singer tap that produces JSON-formatted data following the Singer spec.
This tap:
-
Pulls raw data from SurveyMonkey
-
Extracts the following resources:
- Surveys
- Responses
- Simplified Responses
- Survey Details
-
Outputs the schema for each resource
-
Incrementally pulls data based on the input state
To pull all surveys, the configuration parameters access_token
and start_date
are required.
- To pull all responses or simplified responses or survey_details for a specific survey, the configuration parameters
access_token
,start_date
, andsurvey_id
are required. - To pull all data of responses or simplified responses or survey_details, the configuration parameters
access_token
,start_date
, andsurvey_id
are required.
The parameter page_size
(default: 50, max: 100) is optional to adjust the response-size for faster response times or larger batches thereby and reduced number of API-calls.
The surveys and responses resources will pull data in the form described on the SurveyMonkey API docs.
The Simplified Responses resource will pull a Response schema, with an extra key simple_text
embedded in each of the answer
dictionaries,
which is a human-readable form of the survey respondent's response to question. It also contains the family
, subtype
, and heading
keys in the question
object, for easy reference.
-
Install
Clone this repo
git clone ...
We recommend using a virtualenv:
python3 -m venv ~/.virtualenvs/tap-surveymonkey source ~/.virtualenvs/tap-surveymonkey/bin/activate pip install -e .
-
Create a SurveyMonkey access token
Login to your SurveyMonkey account, go to SurveyMonkey app directory, and put
stitchdata
in the search box to find the Stitchdata app. In there, you can authorize to get an access token. -
Set up your config file.
An example config file is provided in
sample_config.json
, the access token and survey in that file are invalid, and will error out. Replace them with your own valid ones. -
Run the tap in discovery mode to get catalog.json file.
tap-surveymonkey --config config.json --discover > catalog.json
-
In the generated
catalog.json
file, select the streams to sync.Each stream in the
catalog.json
file has aschema
entry. To select a stream to sync, add "selected": true to that stream'sschema
entry. For example, to sync the survey_details stream:"tap_stream_id": "survey_details", "schema": { "selected": true, "properties": { ... } } ...
-
Run the application
tap-surveymonkey can be run with:
tap-surveymonkey --config config.json --catalog catalog.json
-
To run with Stitch Import API with dry run:
tap-surveymonkey --config config.json --catalog catalog.json | target-stitch --config target_config.json --dry-run > state.json
Config property | Required | Description |
---|---|---|
access_token |
Yes | See https://developer.surveymonkey.com/api/v3/#oauth-2-0-flow |
start_date |
Yes | For streams with replication method INCREMENTAL the start date time to be used |
page_size |
No, default "50" |
The page size for paginated streams |
survey_id |
No | In case you just want to get data for just one survey. Does not work with stream surveys . |
- Endpoint: https://api.surveymonkey.com/v3/surveys
- Primary keys: id
- Replication strategy: INCREMENTAL
- Bookmark: date_modified (date-time)
- Endpoint: https://api.surveymonkey.com/v3/surveys/[survey_id]/details
- Primary keys: id
- Replication strategy: INCREMENTAL
- Bookmark: date_modified (date-time)
- Endpoint: https://api.surveymonkey.com/v3/surveys/[survey_id]/responses/bulk
- Primary keys: id
- Replication strategy: INCREMENTAL
- Bookmark: date_modified (date-time)
- Endpoint: https://api.surveymonkey.com/v3/surveys/[survey_id]/responses/bulk
- Primary keys: id
- Replication strategy: INCREMENTAL
- Bookmark: date_modified (date-time)
While developing the tap, run pylint to improve better code quality which is recommended by Singer.io best practices.
pylint tap_surveymonkey -d missing-docstring -d logging-format-interpolation -d too-many-locals -d too-many-arguments
To check the tap and verify working, install singer-tools.
tap-surveymonkey --config tap_config.json --catalog catalog.json | singer-check-tap
Copyright © 2019 Stitch