Comment: | Initial work on the package uploader client. Not yet fully working nor tested. |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | trunk |
Files: | files | file ages | folders |
SHA1: |
43aac904099bd82946d465b133a577e7 |
User & Date: | mistachkin on 2016-12-18 21:53:56 |
Other Links: | manifest | tags |
2016-12-19
| ||
03:57 | Get metadata submission working for the package uploader client. check-in: e45fd33145 user: mistachkin tags: trunk | |
2016-12-18
| ||
21:53 | Initial work on the package uploader client. Not yet fully working nor tested. check-in: 43aac90409 user: mistachkin tags: trunk | |
21:50 | More work on supporting the package uploader client. Use the new OpenPGP 'keys' file (i.e. 'keys.asc', the one with potentially more than one Package Signing Key). Closed-Leaf check-in: 0fc9d3e420 user: mistachkin tags: uploaderClient | |
2016-12-17
| ||
05:31 | Add stub file for the package uploader tool. check-in: 6240d4658d user: mistachkin tags: trunk | |
Modified client/1.0/neutral/pkgd.eagle from [6a1409dce3] to [c1156a1489].
︙ | |||
24 25 26 27 28 29 30 | 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | - + - + - + | # NOTE: This procedure sets up the default values for all URN configuration # parameters used by the package downloader client. If the force # argument is non-zero, any existing values will be overwritten and # set back to their default values. # proc setupDownloadServerVars { force } { # |
︙ | |||
109 110 111 112 113 114 115 | 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 | - + | variable baseUri; # DEFAULT: https://urn.to/r if {$force || ![info exists baseUri]} then { set baseUri https://urn.to/r } # |
︙ | |||
268 269 270 271 272 273 274 | 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 | - + - - - | # # <public> proc useServerId { {serverId ""} } { variable downloadUrn variable loginUrn variable logoutUrn |
︙ | |||
299 300 301 302 303 304 305 | 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 | - + - - - | # downloader client so that a specific version will be used. The # versionId argument must consist only of hexadecimal characters. # # <public> proc useVersionId { {versionId ""} } { variable branchName |
︙ | |||
466 467 468 469 470 471 472 | 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 | - + | set dir $pkgd(savedDir); unset -nocomplain pkgd }]] return "" } # |
︙ | |||
724 725 726 727 728 729 730 731 732 733 734 735 736 737 | 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 | + | # must be one of the literal strings "8.4", "8.5", or "8.6" when the # language is "tcl" -OR- the literal string "1.0" when the language # is either "eagle" or "client". The varName argument is the name # of a scalar variable in the context of the immediate caller that # will receive a boolean value indicating if the specified language # is actually a reference to the package downloader client itself. # # <internal> proc verifyLanguageAndVersion { language version varName } { if {[string length $varName] > 0} then { upvar 1 $varName isClient } set isClient false |
︙ | |||
793 794 795 796 797 798 799 800 801 802 803 804 805 806 | 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 | + + + + + + + + + + + + + + + + + + + + + + + + + + | } } } } return "" } # # NOTE: This procedure verifies that the specified value is indeed a valid # server identifier. The serverId argument is the value to verify. # This procedure may raise script errors. # # <internal> proc verifyServerId { serverId } { if {[string length $serverId] > 0 && \ ![regexp -nocase -- {^[A-Z][0-9A-Z]*$} $serverId]} then { error "server Id must be alphanumeric and start with a letter" } } # # NOTE: This procedure verifies that the specified value is indeed a valid # version identifier. The versionId argument is the value to verify. # This procedure may raise script errors. # # <internal> proc verifyVersionId { versionId } { if {[string length $versionId] > 0 && \ ![regexp -nocase -- {^[0-9A-F]*$} $versionId]} then { error "version Id must be hexadecimal" } } # # NOTE: This procedure verifies the platform specified by the caller. The # platform argument must be an empty string -OR- one of the literal # strings "neutral", "win32-arm", "win32-x86", "win64-arm64", # "win64-ia64", or "win64-x64". An empty string means that the # associated entity does not require a specific platform. The |
︙ |
Modified client/1.0/neutral/pkgd.eagle.asc from [9df36a56d2] to [fc55c91d88].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgd.eagle.harpy from [a7a7bcae74] to [67e18415a4].
︙ | |||
17 18 19 20 21 22 23 | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + | THE ASSOCIATED SOFTWARE MAY NOT WORK PROPERLY IF THIS FILE IS ALTERED. --> <Certificate xmlns="https://eagle.to/2011/harpy" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> <Protocol>None</Protocol> <Vendor>Mistachkin Systems</Vendor> |
Modified client/1.0/neutral/pkgd.eagle.harpy.asc from [782f665a11] to [5ccaa40c80].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr.eagle from [46ce6d2906] to [2df5f1ebc0].
︙ | |||
110 111 112 113 114 115 116 117 118 119 120 121 122 123 | 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 | + | } # # NOTE: This procedure returns a string argument value, which may contain # spaces, for use with the [exec] command. The value argument is # the string value to format as an [exec] argument. # # <internal> proc formatExecArgument { value } { if {[isEagle]} then { return [appendArgs \" $value \"] } else { return $value } } |
︙ | |||
350 351 352 353 354 355 356 | 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 | - + | if {[catch { eval exec -success Success $openPgpInstalledCommand } result]} then { error "cannot use OpenPGP: may not be installed and/or configured" } } else { if {[catch { |
︙ |
Modified client/1.0/neutral/pkgr.eagle.asc from [4f9aea824a] to [683837788b].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr.eagle.harpy from [c814762109] to [c59a944dab].
︙ | |||
17 18 19 20 21 22 23 | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + | THE ASSOCIATED SOFTWARE MAY NOT WORK PROPERLY IF THIS FILE IS ALTERED. --> <Certificate xmlns="https://eagle.to/2011/harpy" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> <Protocol>None</Protocol> <Vendor>Mistachkin Systems</Vendor> |
Modified client/1.0/neutral/pkgr.eagle.harpy.asc from [e6c0f2e243] to [3037ce66b5].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr_setup.eagle from [90601fa7f5] to [3948e4d333].
︙ | |||
84 85 86 87 88 89 90 | 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 | - + | # # NOTE: Verify that the number of command line arguments meets the basic # requirements of this tool. # if {![info exists ::argv] || [llength $::argv] == 0} then { set localFileName [file join \ [::PackageRepository::getFileTempDirectory] [appendArgs \ |
︙ |
Modified client/1.0/neutral/pkgr_setup.eagle.asc from [8cfd7ee50f] to [aa397a518b].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr_setup.eagle.harpy from [e1fa8a613e] to [a8672d71a7].
︙ | |||
17 18 19 20 21 22 23 | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + | THE ASSOCIATED SOFTWARE MAY NOT WORK PROPERLY IF THIS FILE IS ALTERED. --> <Certificate xmlns="https://eagle.to/2011/harpy" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> <Protocol>None</Protocol> <Vendor>Mistachkin Systems</Vendor> |
Modified client/1.0/neutral/pkgr_setup.eagle.harpy.asc from [0d986c32c6] to [18cbd1a590].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr_upload.eagle from [de331db2a1] to [4e70a976f9].
︙ | |||
33 34 35 36 37 38 39 40 41 42 43 44 45 46 | 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 | + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + | [file tail [info nameofexecutable]]\ [file tail [info script]] \[apiKey\] \[name\] \[version\] \[language\]\ \[fileName1\] ... \[fileNameN\]" exit 1 } # # NOTE: This procedure sets up the default values for all configuration # parameters used by the package uploader client. The script # argument is the fully qualified path and file name for the script # being evaluated. # proc setupUploadVars { script } { # # NOTE: What is the fully qualified path to the directory containing the # checkout for the package client? # variable checkoutDirectory if {![info exists checkoutDirectory]} then { set checkoutDirectory [file dirname $script] } # # NOTE: The command to use when attempting to stage package files using # Fossil. # variable fossilAddCommand; # DEFAULT fossil add {${fileName}} if {![info exists fossilAddCommand]} then { set fossilAddCommand {fossil add {${fileName}}} } # # NOTE: The command to use when attempting to commit package files using # Fossil. # variable fossilCommitCommand; # DEFAULT fossil commit ... if {![info exists fossilCommitCommand]} then { set fossilCommitCommand {fossil commit -m {${comment}}\ --branch {${branch}} --user anonymous --chdir \ {${checkoutDirectory}} --no-prompt} } # # NOTE: The regular expression pattern used when attempting to verify # that Fossil committed a set of files. # variable fossilCommitPattern; # DEFAULT: {^New_Version: ([0-9a-f]{40})$} if {![info exists fossilCommitPattern]} then { set fossilCommitPattern {^New_Version: ([0-9a-f]{40})$} } } # # NOTE: This procedure returns a string value, formatted for use within a # script block being processed by the [string map] command. The # value argument is the string value to format. No return value is # reserved to indicate an error. This procedure may not raise any # script errors. # proc formatStringMapValue { value } { if {[string length $value] == 0} then { return \"\" } set list [list $value] if {$value eq $list} then { return $value } else { return $list } } # # NOTE: This procedure counts the common path components for two paths. The # count is returned, zero if there are no common path components. The # path1 and path2 arguments are the paths to compare. This procedure # may not raise script errors. # proc countCommonPathParts { path1 path2 } { set parts1 [file split $path1] set length1 [llength $parts1] set parts2 [file split $path2] set length2 [llength $parts2] set length [expr {min($length1, $length2)}] for {set index 0} {$index < $length} {incr index} { set part1 [lindex $parts1 $index] set part2 [lindex $parts2 $index] if {$part1 ne $part2} then { return $index } } return $length } # # NOTE: This procedure processes a list of (fully?) qualified file names and # tries to determine their common containing directory, if any. The # fileNames argument is the list of (fully?) qualified file names to # process. This procedure may not raise script errors. If there is # no common containing directory, an empty string is returned. # proc getCommonContainingDirectory { fileNames } { set length [llength $fileNames] if {$length == 0} then { return "" } set oldFileName [lindex $fileNames 0] if {$length == 1} then { return [file dirname $oldFileName] } set minimumCount 0 for {set index 1} {$index < $length} {incr index} { set newFileName [lindex $fileNames $index] set newCount [countCommonPathParts $oldFileName $newFileName] if {$newCount == 0} then { return "" } if {$minimumCount == 0 || $newCount < $minimumCount} then { set oldFileName $newFileName set minimumCount $newCount } } if {$minimumCount == 0} then { return "" } incr minimumCount -1 return [eval file join [lrange [file split $oldFileName] 0 $minimumCount]] } # # NOTE: This procedure attempts to process a list of (fully?) qualified file # names and return the corresponding list of relative file names. The # fileNames argument is the list of (fully?) qualified file names to # process. The maximumLevels argument is the maximum path depth that # is allowed for all file names. This procedure may raise script # errors. # proc getRelativeFileNames { fileNames maximumLevels } { set directory [getCommonContainingDirectory $fileNames] set directoryParts [file split $directory] set fileNameIndex [expr {[llength $directoryParts] - 1}] if {$fileNameIndex < 0} then { error [appendArgs \ "invalid containing directory \"" $directory \ "\": cannot go up one level"] } set relativeFileNames [list] foreach fileName $fileNames { set fileNameParts [lrange \ [file split $fileName] $fileNameIndex end] if {$maximumLevels > 0 && \ [llength $fileNameParts] > $maximumLevels} then { error [appendArgs \ "depth for file name \"" $fileName \ "\" exceeds maximum (" $maximumLevels )] } set relativeFileName [eval file join $fileNameParts] if {[string length $relativeFileName] == 0 || \ [file pathtype $relativeFileName] ne "relative"} then { error [appendArgs \ "bad file name \"" $relativeFileName "\", not relative"] } lappend relativeFileNames $relativeFileName } return $relativeFileNames } # # NOTE: This procedure attempts to create a script chunk that appends the # specified list of file names to a list variable. The fileNames # argument is the list of (fully?) qualified file names to append to # the list variable. The maximumLevels argument is the maximum path # depth that is allowed for all file names. This procedure may raise # script errors. # proc getScriptChunkForFileNames { fileNames maximumLevels } { set result "" set relativeFileNames [getRelativeFileNames $fileNames $maximumLevels] foreach relativeFileName $relativeFileNames { if {[string length $result] > 0} then { append result \n } append result { lappend fileNames [file join } append result [file split $relativeFileName] append result \] } return $result } # # NOTE: This procedure creates and returns a script block designed for use # with the package repository server in order to download and provide # a package consisting of a set of files. The serverId argument is # the identifier for the specific server to use, if any. The # versionId argument is the identifier for the specific version to use, # if any. The language argument must be the literal string "eagle" or # the literal string "tcl". The version argument must be one of the # literal strings "8.4", "8.5", or "8.6" when the language is "tcl" # -OR- the literal string "1.0" when the language is "eagle". The # platform argument must be an empty string -OR- one of the literal # strings "neutral", "win32-arm", "win32-x86", "win64-arm64", # "win64-ia64", or "win64-x64". The fileNames argument is the list of # (fully?) qualified file names to be downloaded when the associated # package is being provided. The options argument is reserved for # future use, it should be an empty list. # # <public> proc createRepositoryScript { serverId versionId language version platform fileNames options } { ::PackageDownloader::verifyServerId $serverId ::PackageDownloader::verifyVersionId $versionId ::PackageDownloader::verifyLanguageAndVersion $language $version isClient set prologue "" if {[string length $serverId] > 0} then { append prologue " ::PackageDownloader::useServerId " $serverId \n } if {[string length $versionId] > 0} then { append prologue " ::PackageDownloader::useVersionId " $versionId \n } append prologue " " return [string trim [string map [list \r\n \n \ %language% [formatStringMapValue $language] \ %version% [formatStringMapValue $version] \ %platform% [formatStringMapValue $platform] \ %prologue% $prologue %ns% ::PackageDownloader \ %backslash% \\ %fileNames% \ [getScriptChunkForFileNames $fileNames 2]] { apply [list [list] { package require Eagle.Package.Downloader %prologue%%ns%::resetCookieAndLoginSimple set fileNames [list] %fileNames% set options [list %backslash% -persistent false -usePgp true -useAutoPath true] %ns%::downloadFiles %language% %version% %platform% $fileNames $options %ns%::logoutAndResetCookie }] }]] } # # NOTE: This procedure attempts to stage the specified package files using # Fossil. The fileNames argument is a list of (fully?) qualified # local file names to stage. # # <public> proc stagePackageFiles { language version platform fileNames } { variable checkoutDirectory variable fossilAddCommand set relativeFileNames [getRelativeFileNames $fileNames] set savedPwd [pwd]; cd $checkoutDirectory foreach fileName $fileNames relativeFileName $relativeFileNames { file mkdir [file join \ $language $version $platform [file dirname $relativeFileName]] file copy $fileName $relativeFileName set fileName $relativeFileName if {[isEagle]} then { set fileName [::PackageRepository::formatExecArgument $fileName] if {[catch { eval exec -success Success [subst $fossilAddCommand] } error]} then { cd $savedPwd error [appendArgs \ "failed to stage file \"" $fileName "\": " $error] } } else { if {[catch { eval exec [subst $fossilAddCommand] } error]} then { cd $savedPwd error [appendArgs \ "failed to stage file \"" $fileName "\": " $error] } } } cd $savedPwd } # # NOTE: This procedure attempts to commit the staged package files to the # remote package file repository using Fossil. The varName argument # is the name of a scalar variable in the context of the immediate # caller that will receive the resulting Fossil check-in identifier. # # <public> proc commitPackageFiles { varName } { variable checkoutDirectory variable fossilCommitCommand variable fossilCommitPattern set branch ""; # TODO: Figure out a good branch. set comment ""; # TODO: Figure out a good comment. if {[isEagle]} then { if {[catch { eval exec -nocarriagereturns -stdout output -stderr error \ [subst $fossilCommitCommand] } result] == 0} then { set result [appendArgs $output $error] } else { return false } } else { if {[catch { eval exec [subst $fossilCommitCommand] } result]} then { return false } } if {[string length $varName] > 0} then { upvar 1 $varName checkin } if {![info exists result] || \ ![regexp -line -- $fossilCommitPattern $result dummy checkin]} then { return false } return true } # # NOTE: Figure out the fully qualified path to the current script file. # If necessary, add it to the auto-path for the interpreter. The # necessary supporting packages (i.e. the Package Repository and # other support packages) that are assumed to exist in the same # directory as the current script file. # |
︙ | |||
63 64 65 66 67 68 69 | 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 | + - + - + + + + + + + + + + + + + + + + + + + + + + + + + + | # package. # namespace eval ::PackageRepository { variable verboseUriDownload true } # # NOTE: This package requires both the package repository and downloader |
︙ |
Modified client/1.0/neutral/pkgr_upload.eagle.asc from [60f01e4cc7] to [535ecba6c3].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |
Modified client/1.0/neutral/pkgr_upload.eagle.harpy from [1d2925f0b5] to [08d06ff8a9].
︙ | |||
17 18 19 20 21 22 23 | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + | THE ASSOCIATED SOFTWARE MAY NOT WORK PROPERLY IF THIS FILE IS ALTERED. --> <Certificate xmlns="https://eagle.to/2011/harpy" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> <Protocol>None</Protocol> <Vendor>Mistachkin Systems</Vendor> |
Modified client/1.0/neutral/pkgr_upload.eagle.harpy.asc from [f19af08e58] to [75bba8197e].
1 2 3 4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | - - - - - - - - - - - - - + + + + + + + + + + + + + | -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 Comment: Eagle Package Repository |