Updated Answer
You can programmatically update the script task by replacing the appropriate XML node in the the DTSX file
The node path depends on where the script task has been created within the SSIS package, in my case the node path was
/DTS:Executable/DTS:Executables/DTS:Executable/DTS:ObjectData/pipeline/components/component[@refId="Package\Data Flow Task\Script Component"]/properties
The @refId you will be looking for will start with Package \ Dataflow name \ Component name
data:image/s3,"s3://crabby-images/fd3b3/fd3b3acb22d6fbb4aa6bb57eb0a486af7f6f20da" alt="enter image description here"
This node will have sub nodes which contains the C# scripts as well as the binary that was built off this script
The property name "SourceCode" contains the C# scipts in an array called arrayElements, the array will have three sub nodes for each file, these subnodes are called arrayElement, first value is the relative path and name, second is file encoding and third is the file content
data:image/s3,"s3://crabby-images/5eaef/5eaef9460c10e4bda4d77070a158b876edf7ea9f" alt="SourceCodeNode"
The property name "BinaryCode" contains the .dll that was build from the scripts, it also contains an arrayElement array with two entries, first the dll name and the second the base64 encoded dll binary
data:image/s3,"s3://crabby-images/778ed/778ed86ad3852853eca0ed795809493c82b7ad1d" alt="BinaryCodeNode"
To get the data to populate these items you will need to create a template of the C# build directory, apply your changes, build the code and take the resulting files and replace them on their appropriate nodes
To create the template open the script via SSIS task,
- Click on the project in solution explorer to and go file save VstaProject.sln
data:image/s3,"s3://crabby-images/4ea73/4ea7395cfa08fb4b4dda4e927e611ffba2f59af8" alt="SaveSLN"
- Go to the saved folder, you get the folder off the solutions properties dialog
data:image/s3,"s3://crabby-images/4781e/4781e8b62eee6f370eb71ff5a3da5bd049d56a99" alt="FindTheFolder"
- Copy this folder somewhere so that you can reuse it to build your custom stuff
- Modify the .cs files in your template directory and add your custom reference dll's to your .csproj file
- Call MSBUILD in the same directory as your .csproj to output the dll, its important that you use the VS MSBUILD, VS2017 you can find it in
C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\MSBuild\15.0\Bin\msbuild.exe
- Take these files and package them into a XML node in the DTSX file
Initial Answer
Microsoft provides a workaround for loading DLL's that aren't in the GAC
Load assembly that isnt in the GAC
Please see below extract from a SSIS script, I loaded the JSON dll's from the nuget install directory. This DLL is not in the GAC
static ScriptMain()
{
AppDomain.CurrentDomain.AssemblyResolve += new ResolveEventHandler(CurrentDomain_AssemblyResolve);
}
static System.Reflection.Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
{
if (args.Name.Contains("Newtonsoft.Json"))
{
string path = @"C:\Program Files\Microsoft SDKs\Azure\.NET SDK\v2.9\bin\plugins\Diagnostics\";
return System.Reflection.Assembly.LoadFile(System.IO.Path.Combine(path, "Newtonsoft.Json.dll"));
}
return null;
}