Skip to content

Commit 3171a3b

Browse files
authored
Merge pull request #1031 from dbrownems/master
Updated T4 template for SQL Script and misc fixes
2 parents 1e89bcb + 4720aa9 commit 3171a3b

3 files changed

Lines changed: 17 additions & 10 deletions

File tree

samples/features/sql-clr/Curl/Curl.cs

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,10 +9,16 @@
99
/// </summary>
1010
public partial class Curl
1111
{
12+
static Curl()
13+
{
14+
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
15+
}
16+
1217
[SqlFunction]
1318
[return: SqlFacet(MaxSize = -1)]
1419
public static SqlChars Get(SqlChars H, SqlChars url)
1520
{
21+
1622
var client = new WebClient();
1723
AddHeader(H, client);
1824
return new SqlChars(
@@ -24,6 +30,7 @@ public static SqlChars Get(SqlChars H, SqlChars url)
2430
[SqlProcedure]
2531
public static void Post(SqlChars H, SqlChars d, SqlChars url)
2632
{
33+
2734
var client = new WebClient();
2835
AddHeader(H, client);
2936
if (d.IsNull)
@@ -39,6 +46,7 @@ public static void Post(SqlChars H, SqlChars d, SqlChars url)
3946
[SqlProcedure]
4047
public static void PostWithRetry(SqlChars H, SqlChars d, SqlChars url)
4148
{
49+
4250
var client = new WebClient();
4351
AddHeader(H, client);
4452
if (d.IsNull)

samples/features/sql-clr/Curl/SqlClrCurl.csproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99
<AppDesignerFolder>Properties</AppDesignerFolder>
1010
<RootNamespace>SqlClr</RootNamespace>
1111
<AssemblyName>SqlClrCurl</AssemblyName>
12-
<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
12+
<TargetFrameworkVersion>v4.7.2</TargetFrameworkVersion>
1313
<FileAlignment>512</FileAlignment>
1414
<TargetFrameworkProfile />
1515
</PropertyGroup>

samples/features/sql-clr/Curl/SqlClrCurl.tt

Lines changed: 8 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -24,27 +24,26 @@ SELECT @hash = hash
2424
FROM sys.trusted_assemblies ta
2525
WHERE ta.description = N'SqlClrCurl'
2626

27-
EXEC sp_drop_trusted_assembly @hash;
27+
if (@hash is not null)
28+
EXEC sp_drop_trusted_assembly @hash;
2829
GO
2930

3031
--Drop the assembly if it already exists
3132
DROP ASSEMBLY IF EXISTS SqlClrCurl;
3233
GO
3334

34-
35+
DECLARE @assembly VARBINARY(MAX) = <#= "0x" + BitConverter.ToString(System.IO.File.ReadAllBytes(this.Host.ResolvePath("bin\\Release\\SqlClrCurl.dll"))).Replace("-","") #>
3536
DECLARE @hash VARBINARY(64);
36-
SELECT @hash = HASHBYTES('SHA2_512', BulkColumn)
37-
FROM OPENROWSET(BULK '<#= this.Host.ResolvePath("bin\\Release\\SqlClrCurl.dll") #>', SINGLE_BLOB) AS assembly_content
37+
SELECT @hash = HASHBYTES('SHA2_512', @assembly)
3838

39-
IF(@hash IS NOT NULL)
39+
IF(not exists (select * from sys.trusted_assemblies where hash = @hash))
4040
EXEC sp_add_trusted_assembly @hash, N'SqlClrCurl'
4141
ELSE
42-
PRINT 'Cannot create hash for assembly!'
43-
GO
42+
print 'Hash already exists'
4443

4544
--Create the assembly
4645
CREATE ASSEMBLY SqlClrCurl
47-
FROM '<#= this.Host.ResolvePath("bin\\Release\\SqlClrCurl.dll") #>'
46+
FROM @assembly
4847
WITH PERMISSION_SET = EXTERNAL_ACCESS;
4948
GO
5049

@@ -60,4 +59,4 @@ GO
6059

6160
CREATE PROCEDURE CURL.XPOST (@H NVARCHAR(MAX), @d NVARCHAR(MAX), @url NVARCHAR(4000))
6261
AS EXTERNAL NAME SqlClrCurl.Curl.Post;
63-
GO
62+
GO

0 commit comments

Comments
 (0)