From 67410041838ece2132ee5bd8f6355cab0d0a9bac Mon Sep 17 00:00:00 2001 From: KevM Date: Wed, 7 Dec 2016 23:23:24 -0600 Subject: [PATCH] Rework assembly signing to get .snk from environment When the .snk is not present it is not used. --- .gitignore | 1 + TextExtraction.snk | Bin 596 -> 0 bytes appveyor.yml | 2 ++ build.fsx | 32 +++++++++++++++--- .../TextExtraction.snk | Bin 596 -> 0 bytes .../TikaOnDotnet.TextExtraction.csproj | 21 ++++-------- 6 files changed, 38 insertions(+), 18 deletions(-) delete mode 100644 TextExtraction.snk delete mode 100644 src/TikaOnDotnet.TextExtractor/TextExtraction.snk diff --git a/.gitignore b/.gitignore index e703347..38c25a4 100644 --- a/.gitignore +++ b/.gitignore @@ -13,3 +13,4 @@ build SolutionInfo.cs .paket/paket.exe paket-files +*.snk \ No newline at end of file diff --git a/TextExtraction.snk b/TextExtraction.snk deleted file mode 100644 index 578f3d2490ffcca3007b1fe1c5724d397b81f8f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 596 zcmV-a0;~N80ssI2Bme+XQ$aES1ONa50096|T1nX_EN3BdXYV^5F*mOM&OD9?gGnWBCP8#-`$(6ScN!V9#EcL z!7&;RJR5u3sw#5F1lu&*700?T-ibf5vQ9HGw0K5YKVP0BXqJZf)8{8;FmI=brCq+W zySi*5D<5t=+oO+rcRTPQ>GBcJ(HSmAYH0TyyanZKk?5*WL%#@Q%V6;*R#;N{xz%(8 z9ntA{pnBP1_8@`fScg4$e{cpx~S?a0Un4mt8i67ut#@mx^gl& zp)mIY5e9_?8yP^d+5qPvW2s2;b7cRuWCDQ}R5PoCL>e*!Phw|!f{ufba2DkuOzsmW zq&swrKed}AZ_bX2k)p&+ktkLvCoi*F?HSg^NU2O9j;lI(49K>o+|xn2NnRu}%IED0 z1^w_^aLH^-l!5}MPb|Od1*J{ar@4ln2?`eYL?@YwCKaqd3#5n~_$}izlL}^TLpBKj z<8Ezm7Wl*qLEv7tcAw<2w67p+DuWEs84K=KllrX7&Sio;I+H)IGkDyg=d)(7 z_whMFaSLL;J15<)z5uuii0ZLzt3?&jZ%6}!i@2`B`2o9*hYY}`=^Ttnt@UGgz1ug- ix_VeNAgh!&I`U6kijmm$b+`Jnj6jWy3WSmKM3oNr%@SDv diff --git a/appveyor.yml b/appveyor.yml index 15157e7..0cce36c 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -1,5 +1,7 @@ version: 1.0.{build} environment: + snk: + secure: K+FJ6oBTI+HLJhAiHeQN+Ryofta7b8xBrFYq8UJSXyhLyLGPCqcEseUUbs5emkSXV+EfiPGtTngYlafMXynFulhra5MDfWm8r37Go7WOPaDmxH7nvxnarBs/mIFuxOWzxiAlyfDbmzYagGlEoqeWpcMdGGIz1rrqPm9EIS0RNQ5rymfXIQzit7tEaRprHSEN9Jl0gua48BXKFi+s7gRmsNbbCrLshxybXfjcMz+jcaw7U+rtcHD4RjNf9NVqIXPnSseAZxLWZgvYqksJ44T7Nsn6GNSEap1TGReGls8xkwAxPVpPvrq6NSTiJsGU501YU8Vhy2LXFyVUg0H0QMol2YDRfvIiVIhO/mGbtkech/qM1zUpK47n/n2H4Ivy+KGZ+S301qhacKLY5Ts1Mn4OUaPBOWsgAn/s2dSz/lTlYU0lEdiaJg6G06j4jghnvip3PsW/CPG77yMidSN07itMB2m8V7e8idNpoQajDDtz7Xch/1CUMzfiFiS1E6TA/xJXbFOvq3fLthYe2mXpZG5Zuk72bop2eBpvOQaSu9qsSBASVO8j4Ekrr1P59B6IWE/1kcD4XI7sT+hUBD9kpJgoGoUyVS/xWuiDdTuaO1FfBIVI6VEYv+6W1f8Sa6E+lnuzq691l7gmlguf0os+uIqQ7YAtXyrB3jYJJMZOHgsDHMGh4g89MmTsS/qxgaYQoGGAx3GeDX0g+GUDsJMGwXb1xcCphHlOY5uzyk8Yw5t+sVoKgSOEumRc2bIBkRx8dKmZx/50pl75Mdvtpdf4Kb374ryefGaeAGFBTfbuy0CWxML6G8Kj4JM7HmzmBuYMA6UJ3Spnnjrems9lIMgZShqTFH6kiL4XYMUwTUoNyT7acPER0owryawF+Df2h1uxkD7gzGQZMAdLRJ4mQQx+ALd8sk7dMrYS+W08j3R3zXU4pj9jdYt1CJiaO6m0x2dUOiwXXkyGp6dvR0oHCBGDT08DrbsSfZ+bd4viiFKNl1ciDHgU4PiXJ8a+z2GwTIsBqK+vfDyXNtcU6LdeM+PbdqGqAHcZMjV81xHJoFfgGFdrvc8Cmh/0N3SCCBTSo5TX3S+d nugetkey: secure: JNpnpSglMOIdpmkuqgvwvY6jzqEabYZH1hRziq/GddbsMNWyObRk07km0SZYBfT1 build_script: diff --git a/build.fsx b/build.fsx index be9583c..46be346 100644 --- a/build.fsx +++ b/build.fsx @@ -18,6 +18,8 @@ let tempDir = "temp" let tikaLibDir = "lib" let solutionFile = "src/TikaOnDotNet.sln" +let keyFile = (fileInfo "TikaOnDotNet.snk") + let []rootPath = __SOURCE_DIRECTORY__ let testAssemblies = "src/**/bin/Release/*Tests*.dll" type root = FileSystem @@ -54,10 +56,13 @@ let IKVMCompile workingDirectory tasks = let rec compile (task:IKVMcTask) = let getIKVMCommandLineArgs() = let sb = Text.StringBuilder() - bprintf sb "-keyfile:..\TextExtraction.snk -target:library -assembly:%s" - (task.AssemblyName) + + if keyFile.Exists + then bprintf sb "-keyfile:%s -target:library -assembly:%s" keyFile.FullName task.AssemblyName + if not <| String.IsNullOrEmpty(task.Version) then task.Version |> bprintf sb " -version:%s" + bprintf sb " %s -out:%s" (task.JarFile |> getNewFileName ".jar") (task.AssemblyName + ".dll") @@ -68,7 +73,7 @@ let IKVMCompile workingDirectory tasks = tasks |> Seq.iter compile Target "Clean" (fun _ -> - CleanDirs [artifactDir; tempDir; tikaLibDir] + CleanDirs [artifactDir; tempDir; tikaLibDir] ) Target "SetVersions" (fun _ -> @@ -80,8 +85,13 @@ Target "SetVersions" (fun _ -> ) Target "Build" (fun _ -> + let strongName = + if keyFile.Exists + then ["SignAssembly","true"; "AssemblyOriginatorKeyFile",keyFile.FullName] + else [] + !! solutionFile - |> MSBuildRelease "" "Clean;Rebuild" + |> MSBuildReleaseExt "" strongName "Clean;Rebuild" |> ignore ) @@ -116,8 +126,22 @@ Target "PublishNugets" (fun _ -> WorkingDir = artifactDir }) ) +Target "BuildSNK" (fun _ -> + let snkBase64 = environVarOrNone "snk" + match snkBase64 with + | Some env -> + ( + trace "Replacing .snk" + keyFile.Delete |> ignore + let snkbytes = System.Convert.FromBase64String(env) + System.IO.File.WriteAllBytes(keyFile.FullName, snkbytes) + ) + | None -> trace "No key found in the \"snk\" environment" +) + "Clean" ==> "SetVersions" + ==> "BuildSNK" ==> "CompileTikaLib" ==> "Build" ==> "RunTests" diff --git a/src/TikaOnDotnet.TextExtractor/TextExtraction.snk b/src/TikaOnDotnet.TextExtractor/TextExtraction.snk deleted file mode 100644 index 578f3d2490ffcca3007b1fe1c5724d397b81f8f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 596 zcmV-a0;~N80ssI2Bme+XQ$aES1ONa50096|T1nX_EN3BdXYV^5F*mOM&OD9?gGnWBCP8#-`$(6ScN!V9#EcL z!7&;RJR5u3sw#5F1lu&*700?T-ibf5vQ9HGw0K5YKVP0BXqJZf)8{8;FmI=brCq+W zySi*5D<5t=+oO+rcRTPQ>GBcJ(HSmAYH0TyyanZKk?5*WL%#@Q%V6;*R#;N{xz%(8 z9ntA{pnBP1_8@`fScg4$e{cpx~S?a0Un4mt8i67ut#@mx^gl& zp)mIY5e9_?8yP^d+5qPvW2s2;b7cRuWCDQ}R5PoCL>e*!Phw|!f{ufba2DkuOzsmW zq&swrKed}AZ_bX2k)p&+ktkLvCoi*F?HSg^NU2O9j;lI(49K>o+|xn2NnRu}%IED0 z1^w_^aLH^-l!5}MPb|Od1*J{ar@4ln2?`eYL?@YwCKaqd3#5n~_$}izlL}^TLpBKj z<8Ezm7Wl*qLEv7tcAw<2w67p+DuWEs84K=KllrX7&Sio;I+H)IGkDyg=d)(7 z_whMFaSLL;J15<)z5uuii0ZLzt3?&jZ%6}!i@2`B`2o9*hYY}`=^Ttnt@UGgz1ug- ix_VeNAgh!&I`U6kijmm$b+`Jnj6jWy3WSmKM3oNr%@SDv diff --git a/src/TikaOnDotnet.TextExtractor/TikaOnDotnet.TextExtraction.csproj b/src/TikaOnDotnet.TextExtractor/TikaOnDotnet.TextExtraction.csproj index e948c3c..683aae7 100644 --- a/src/TikaOnDotnet.TextExtractor/TikaOnDotnet.TextExtraction.csproj +++ b/src/TikaOnDotnet.TextExtractor/TikaOnDotnet.TextExtraction.csproj @@ -34,16 +34,10 @@ - - true - - - TextExtraction.snk - - + False ..\..\lib\TikaOnDotNet.dll @@ -60,17 +54,16 @@ - -