Video tutorial
Watch this quick video to see the integration in action. It walks you through the end-to-end setup, including:
- Installing the SSIS PowerPack
- Configuring a secure connection to Asana
- Working with Asana data directly inside SSIS
- Exploring advanced API Source features
Ready to dive in? Download the product to jump right in, or follow the step-by-step guide below to see how it works.
Prerequisites
Before we begin, make sure the following prerequisites are met:
- SQL Server Data Tools (SSDT) designer installed for Visual Studio.
- SQL Server Integration Services Projects 2022+ Visual Studio extension installed.
- SSIS PowerPack is installed.
Make generic REST API request in SSIS
-
Open Visual Studio and click Create a new project.
-
Select Integration Services Project. Enter a name and location for your project, then click OK.
-
From the SSIS Toolbox, drag and drop a Data Flow Task onto the Control Flow surface, and double-click it:
-
Make sure you are in the Data Flow Task designer:
-
Read the data from the source, using any desired source component. You can even make an API call using the ZappySys JSON/XML/API Source and read data from there. In this example, we will use an OLE DB Source component to read real-time data from a SQL Server database.
-
From the SSIS Toolbox drag and drop API Destination (Predefined Templates) on the Data Flow Designer surface and connect source component with it, and double click to edit it.
-
Select New Connection to create a new connection:
API Destination - AsanaRead and write Asana data effortlessly. Integrate, manage, and automate tasks, projects, workspaces, and time entries — almost no coding required.
-
To configure the Asana connector, choose one of the following methods:
- Choose from Popular Connector List: Select a pre-installed service directly from the dropdown menu.
- Search Online: Use this to find and download a new connector file to your computer.
- Use Saved/Downloaded File: Once the file is downloaded, browse your local drive to load it into the configuration.
After that, just click Continue >>:
Asana
-
Proceed with selecting the desired Authentication Type. Then select API Base URL (in most cases default one is the right one). Finally, fill in all the required parameters and set optional parameters if needed. You may press a link Steps to Configure which will help set certain parameters. More info is available in Authentication section.
Personal Access Token
Asana authentication
Here is how to obtain a Personal Access Token (PAT) in Asana:-
Open My apps in Asana portal
and click Create new token button:
-
Once a popup opens, name your new token:
-
Then click Copy button to copy the token:
- Now go to SSIS package or ODBC data source and use this token in Personal Access Token authentication configuration.
- Choose Default Workspace and Default Project to work with.
- Click Test Connection to confirm the connection is working.
- Done! Now you are ready to use Asana Connector!
API Connection Manager configuration
Just perform these simple steps to finish authentication configuration:
-
Set Authentication Type to
Personal Access Token [Http] - Optional step. Modify API Base URL if needed (in most cases default will work).
- Fill in all the required parameters and set optional parameters if needed.
- Finally, hit OK button:
AsanaPersonal Access Token [Http]https://app.asana.com/api/1.0Required Parameters Enter Token (Personal Access Token - PAT) Fill-in the parameter... Default Workspace Fill-in the parameter... Default Project Fill-in the parameter... Optional Parameters RetryMode RetryWhenStatusCodeMatch RetryStatusCodeList 429 RetryCountMax 5 RetryMultiplyWaitTime True
Find full details in the Asana Connector authentication reference.OAuth app
Asana authentication
Here is how to register an OAuth app in Asana:-
Open My apps in Asana portal
and click Create new app button:
-
Once a popup opens, name your app and check two options, and click Create app button:
-
Then copy Client ID and Client secret and save them in a file (we will need them for authentication):
-
Continue by selecting OAuth menu item on your left and click Add redirect URL button (you can have your own or use
https://zappysys.com/oauth):
- Proceed by clicking on the Manage distribution section on your left.
-
Then specify workspaces your app needs to access (use Any workspace to access them all):
- Once you do that, click Save changes button.
- Now go to SSIS package or ODBC data source and use Client ID, Client Secret, and Redirect URL in OAuth app authentication configuration.
- When you are done with that, click Generate Token button to generate Access and Refresh Tokens.
- Choose Default Workspace and Default Project to work with.
- Click Test Connection to confirm the connection is working.
- Done! Now you are ready to use Asana Connector!
API Connection Manager configuration
Just perform these simple steps to finish authentication configuration:
-
Set Authentication Type to
OAuth app [OAuth] - Optional step. Modify API Base URL if needed (in most cases default will work).
- Fill in all the required parameters and set optional parameters if needed.
- Press Generate Token button to generate the tokens.
- Finally, hit OK button:
AsanaOAuth app [OAuth]https://app.asana.com/api/1.0Required Parameters ClientId Fill-in the parameter... Client Secret Fill-in the parameter... Default Workspace (** Select after Token is generated **) Fill-in the parameter... Default Project (** Select after Token is generated **) Fill-in the parameter... Optional Parameters Permissions default Redirect URL https://zappysys.com/oauth RetryMode RetryWhenStatusCodeMatch RetryStatusCodeList 429 RetryCountMax 5 RetryMultiplyWaitTime True
Find full details in the Asana Connector authentication reference. -
Open My apps in Asana portal
and click Create new token button:
-
Select Generic Table (Bulk Read / Write) table from the dropdown, then select Insert, Update as operation, and hit Preview Data:
API Destination - AsanaRead and write Asana data effortlessly. Integrate, manage, and automate tasks, projects, workspaces, and time entries — almost no coding required.AsanaGeneric Table (Bulk Read / Write)Insert, UpdateRequired Parameters Url Fill-in the parameter... Request Method Fill-in the parameter... Optional Parameters IsMultiPart Filter Request Format (Content-Type) Default Body {$rows$} JsonOutputFormat Multicontent DoNotOutputNullProperty Batch Size (Default=1) 1 Meta Detection Order StaticDynamicVirtual Input Columns - For Mapping (e.g. MyCol1:string(10); MyCol2:int32 ...) - Use bool, int32, int64, datetime, decimal, double Output Columns (e.g. MyCol1:string(10); MyCol2:int32 ...) - Use bool, int32, int64, datetime, decimal, double Request Format Response Format Default Headers Accept: */* || Cache-Control: no-cache Csv - Column Delimiter , Csv - Row Delimiter {NEWLINE} Csv - Quote Around Value True Csv - Always Quote regardless type Encoding CharacterSet Writer DateTime Format Csv - Has Header Row True Xml - ElementsToTreatAsArray Layout Map <?xml version="1.0" encoding="utf-8"?> <!-- Example#1: Output all columns --> <settings> <dataset id="root" main="True" readfrominput="True" /> <map src="*" /> </settings> <!-- Example#2: Records under array <?xml version="1.0" encoding="utf-8"?> <settings singledataset="True"> <dataset id="root" main="True" readfrominput="True" /> <map name="MyArray" dataset="root" maptype="DocArray"> <map src="OrderID" name="OrderID" /> <map src="OrderDate" name="OrderDate" /> </map> </settings> --> <!-- Example#3: Records under nested section <?xml version="1.0" encoding="utf-8"?> <settings> <dataset id="dsRoot" main="True" readfrominput="True" /> <map name="NestedSection"> <map src="OrderID" name="OrderID_MyLabel" /> <map src="OrderDate" name="OrderDate_MyLabel" /> </map> </settings> -->
-
Finally, map the desired columns:
API Destination - AsanaRead and write Asana data effortlessly. Integrate, manage, and automate tasks, projects, workspaces, and time entries — almost no coding required.
-
That's it; we successfully configured the POST API Call. In a few clicks we configured the Asana API call using ZappySys Asana Connector
Asana Connector actions
Need another use case? Pick the next Asana action in SSIS below.
- Download Attachment
- Download Multiple Attachments
- Get Allocations
- Get Attachments (For Project refer to Key-Resources Upload only)
- Get Goals
- Get Memberships
- Get Portfolio Custom Fields
- Get Portfolios
- Get Project (Single)
- Get Project Custom Fields
- Get Project Section
- Get Project Sections
- Get Projects
- Get Sub Tasks
- Get Tags
- Get Task (Single)
- Get Tasks
- Get Time Tracking Entries
- Get User (Single)
- Get User Task Lists
- Get Users
- Get Workspace (Single)
- Get Workspace Custom Fields
- Get Workspace Tasks
- Get Workspace Teams
- Get Workspaces
- Search Tasks (Advanced Filter)
- Make Generic REST API Request
Conclusion
You now know how to make generic REST API request (bulk write) in SSIS without writing complex code. Asana Connector handled pagination and authentication automatically.
Ready to get started? Download the trial or ping us via chat if you need help: