realityforge-buildr 1.5.10 → 1.5.15

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 18706f32d591f5eee4b371e56f0e9ab2eae2faeab9e3b108c785727939c9089a
4
- data.tar.gz: d27fbad9b2d4ec3a1965d15cfbde2ad56222f6f0569a574c280dfe59d5e23fa7
3
+ metadata.gz: d8fa34dd92a2579440a4004d0b4a90d43e0cba4302d19e2f7d983db46984123d
4
+ data.tar.gz: 1b3adb97db7e6bd180232bd89a97d177c3701423a37eee8711e1e14c6b87b00e
5
5
  SHA512:
6
- metadata.gz: 408323c4e663adaa82994b3192a48def7380cf05aa4b6bf264617195141f7d1cb4875918d32a7bb8e6dea03a0b5c3a5e83f49739c27122dd58214ef23f63b08a
7
- data.tar.gz: a06f1222cb77ec21ed799ab6655f4bfcb761fa150c4459e20710314e40500546b0e73faf980ce8c2089dfe1eda11cfccbdea7b9bc1fb4b9a04280104966f05b5
6
+ metadata.gz: 97881c109b09796e52353d719ba96ea0efc7277f5ce8f6f80c30e12109ebd202e6b97aae56f1833f3d09d12ec870cd906ac90183174d3b881b3903d5c638c385
7
+ data.tar.gz: 4ff07b06229fe1cbcdbf0e47028e8ac8758c408f0929a7a5397edf05d6653fb54866e433b5970f0acc14fe611b42ec0e100aa25aac0db639fe3d8975aa4ded88
@@ -220,7 +220,7 @@ module Buildr
220
220
  project.task('checkstyle:xml') do
221
221
  puts 'Checkstyle: Analyzing source code...'
222
222
  mkdir_p File.dirname(project.checkstyle.xml_output_file)
223
- source_paths = project.checkstyle.complete_source_paths.select{|p| !p.start_with?(project._(:generated).to_s)}
223
+ source_paths = project.checkstyle.complete_source_paths.select{|p| !p.start_with?(project._(:target, :generated).to_s)}
224
224
  source_paths = source_paths.collect{|p|::Buildr::Util.relative_path(File.expand_path(p.to_s), project.base_dir)}
225
225
  Buildr::Checkstyle.checkstyle(project.checkstyle.configuration_file,
226
226
  project.checkstyle.format,
@@ -15,27 +15,7 @@
15
15
  module Buildr
16
16
  # Provides the shade method.
17
17
  module Shade
18
-
19
18
  class << self
20
-
21
- # The specs for requirements
22
- def dependencies
23
- %w(
24
- net.sourceforge.pmd:pmd-core:jar:6.11.0
25
- net.sourceforge.pmd:pmd-java:jar:6.11.0
26
- net.sourceforge.pmd:pmd-java8:jar:6.11.0
27
- jaxen:jaxen:jar:1.1.6
28
- commons-io:commons-io:jar:2.6
29
- com.beust:jcommander:jar:1.72
30
- org.ow2.asm:asm:jar:7.1
31
- com.google.code.gson:gson:jar:2.8.5
32
- net.java.dev.javacc:javacc:jar:5.0
33
- net.sourceforge.saxon:saxon:jar:9.1.0.8
34
- org.apache.commons:commons-lang3:jar:3.8.1
35
- org.antlr:antlr4-runtime:jar:4.7
36
- )
37
- end
38
-
39
19
  def shade(input_jar, output_jar, relocations = {})
40
20
 
41
21
  shaded_jar = (input_jar.to_s + '-shaded')
@@ -51,7 +31,7 @@ module Buildr
51
31
  args << '--output'
52
32
  args << shaded_jar.to_s
53
33
  relocations.each_pair do |k, v|
54
- args << "-r#{k}#{v}"
34
+ args << "-r#{k}=#{v}"
55
35
  end
56
36
 
57
37
  sh args.join(' ')
@@ -25,7 +25,7 @@ module Buildr
25
25
  include Extension
26
26
 
27
27
  before_define do |project|
28
- project.layout[:target, :generated] = "generated"
28
+ project.layout[:target, :generated] = 'generated'
29
29
  project.clean { rm_rf project._(:target, :generated) }
30
30
  end
31
31
  end
data/lib/buildr.rb CHANGED
@@ -50,6 +50,7 @@ require 'buildr/core/test'
50
50
  require 'buildr/java/commands'
51
51
  require 'buildr/core/transports'
52
52
  require 'buildr/java/pom'
53
+ require 'buildr/java/publish'
53
54
  require 'buildr/core/doc'
54
55
  require 'buildr/packaging/version_requirement'
55
56
  require 'buildr/packaging/artifact_namespace'
@@ -117,7 +117,7 @@ module Buildr #:nodoc:
117
117
 
118
118
  def create_component(name, attrs = {})
119
119
  target = StringIO.new
120
- Builder::XmlMarkup.new(:target => target, :indent => 2).component({:name => name}.merge(attrs)) do |xml|
120
+ Builder::XmlMarkup.new(:target => target, :indent => 2).component({ :name => name }.merge(attrs)) do |xml|
121
121
  yield xml if block_given?
122
122
  end
123
123
  Buildr::IntellijIdea.new_document(target.string).root
@@ -219,7 +219,7 @@ module Buildr #:nodoc:
219
219
  end
220
220
 
221
221
  def annotation_paths
222
- @annotation_paths ||= [buildr_project._(:source, :main, :annotations)].select {|p| File.exist?(p)}
222
+ @annotation_paths ||= [buildr_project._(:source, :main, :annotations)].select { |p| File.exist?(p) }
223
223
  end
224
224
 
225
225
  def main_source_directories
@@ -349,7 +349,7 @@ module Buildr #:nodoc:
349
349
  name = options[:name] || 'Web'
350
350
  default_webroots = {}
351
351
  default_webroots[buildr_project._(:source, :main, :webapp)] = '/' if File.exist?(buildr_project._(:source, :main, :webapp))
352
- buildr_project.assets.paths.each {|p| default_webroots[p] = '/' }
352
+ buildr_project.assets.paths.each { |p| default_webroots[p] = '/' }
353
353
  webroots = options[:webroots] || default_webroots
354
354
  default_deployment_descriptors = []
355
355
  %w(web.xml sun-web.xml glassfish-web.xml jetty-web.xml geronimo-web.xml context.xml weblogic.xml jboss-deployment-structure.xml jboss-web.xml ibm-web-bnd.xml ibm-web-ext.xml ibm-web-ext-pme.xml).
@@ -375,7 +375,7 @@ module Buildr #:nodoc:
375
375
  end
376
376
  end
377
377
  end
378
- default_enable_jsf = webroots.keys.any?{|webroot| File.exist?("#{webroot}/WEB-INF/faces-config.xml")}
378
+ default_enable_jsf = webroots.keys.any? { |webroot| File.exist?("#{webroot}/WEB-INF/faces-config.xml") }
379
379
  enable_jsf = options[:enable_jsf].nil? ? default_enable_jsf : options[:enable_jsf]
380
380
  enable_jsf = false if buildr_project.root_project.ipr? && buildr_project.root_project.ipr.version >= '13'
381
381
  f.facet(:type => 'jsf', :name => 'JSF') do |jsf|
@@ -404,8 +404,8 @@ module Buildr #:nodoc:
404
404
  provider = options[:provider_enabled]
405
405
  else
406
406
  provider = nil
407
- {'org.hibernate.ejb.HibernatePersistence' => 'Hibernate',
408
- 'org.eclipse.persistence.jpa.PersistenceProvider' => 'EclipseLink'}.
407
+ { 'org.hibernate.ejb.HibernatePersistence' => 'Hibernate',
408
+ 'org.eclipse.persistence.jpa.PersistenceProvider' => 'EclipseLink' }.
409
409
  each_pair do |match, candidate_provider|
410
410
  deployment_descriptors.each do |descriptor|
411
411
  if File.exist?(descriptor) && /#{Regexp.escape(match)}/ =~ IO.read(descriptor)
@@ -608,7 +608,7 @@ module Buildr #:nodoc:
608
608
  unless paths.empty?
609
609
  xml.tag!('annotation-paths') do |xml|
610
610
  paths.each do |path|
611
- xml.root(:url=> file_path(path))
611
+ xml.root(:url => file_path(path))
612
612
  end
613
613
  end
614
614
  end
@@ -618,14 +618,14 @@ module Buildr #:nodoc:
618
618
  xml.content(:url => 'file://$MODULE_DIR$') do
619
619
  # Source folders
620
620
  [
621
- {:dirs => (self.main_source_directories.dup - self.main_generated_source_directories)},
622
- {:dirs => self.main_generated_source_directories, :generated => true},
623
- {:type => 'resource', :dirs => (self.main_resource_directories.dup - self.main_generated_resource_directories)},
624
- {:type => 'resource', :dirs => self.main_generated_resource_directories, :generated => true},
625
- {:test => true, :dirs => (self.test_source_directories - self.test_generated_source_directories)},
626
- {:test => true, :dirs => self.test_generated_source_directories, :generated => true},
627
- {:test => true, :type => 'resource', :dirs => (self.test_resource_directories - self.test_generated_resource_directories)},
628
- {:test => true, :type => 'resource', :dirs => self.test_generated_resource_directories, :generated => true},
621
+ { :dirs => (self.main_source_directories.dup - self.main_generated_source_directories) },
622
+ { :dirs => self.main_generated_source_directories, :generated => true },
623
+ { :type => 'resource', :dirs => (self.main_resource_directories.dup - self.main_generated_resource_directories) },
624
+ { :type => 'resource', :dirs => self.main_generated_resource_directories, :generated => true },
625
+ { :test => true, :dirs => (self.test_source_directories - self.test_generated_source_directories) },
626
+ { :test => true, :dirs => self.test_generated_source_directories, :generated => true },
627
+ { :test => true, :type => 'resource', :dirs => (self.test_resource_directories - self.test_generated_resource_directories) },
628
+ { :test => true, :type => 'resource', :dirs => self.test_generated_resource_directories, :generated => true },
629
629
  ].each do |content|
630
630
  content[:dirs].map { |dir| dir.to_s }.compact.sort.uniq.each do |dir|
631
631
  options = {}
@@ -658,14 +658,14 @@ module Buildr #:nodoc:
658
658
  end
659
659
 
660
660
  def generate_project_dependency(xml, other_project, export, test = false)
661
- attribs = {:type => 'module', 'module-name' => other_project}
661
+ attribs = { :type => 'module', 'module-name' => other_project }
662
662
  attribs[:exported] = '' if export
663
663
  attribs[:scope] = 'TEST' if test
664
664
  xml.orderEntry attribs
665
665
  end
666
666
 
667
667
  def generate_module_lib(xml, path, export, source_path, annotations_path, test = false)
668
- attribs = {:type => 'module-library'}
668
+ attribs = { :type => 'module-library' }
669
669
  attribs[:exported] = '' if export
670
670
  attribs[:scope] = 'TEST' if test
671
671
  xml.orderEntry attribs do
@@ -691,7 +691,7 @@ module Buildr #:nodoc:
691
691
  net = []
692
692
  all = self.excluded_directories.map { |dir| buildr_project._(dir.to_s) }.sort_by { |d| d.size }
693
693
  all.each_with_index do |dir, i|
694
- unless all[0 ... i].find { |other| dir =~ /^#{other}/ }
694
+ unless all[0...i].find { |other| dir =~ /^#{other}/ }
695
695
  net << dir
696
696
  end
697
697
  end
@@ -725,6 +725,10 @@ module Buildr #:nodoc:
725
725
  @jdk_version ||= buildr_project.compile.options.source || '1.7'
726
726
  end
727
727
 
728
+ def compiler_configuration_options
729
+ @compiler_configuration_options ||= {}
730
+ end
731
+
728
732
  def nonnull_assertions?
729
733
  @nonnull_assertions.nil? ? true : !!@nonnull_assertions
730
734
  end
@@ -781,7 +785,7 @@ module Buildr #:nodoc:
781
785
 
782
786
  def add_postgres_data_source(name, options = {})
783
787
  if options[:url].nil? && options[:database]
784
- default_url = "jdbc:postgresql://#{(options[:host] || '127.0.0.1')}:#{(options[:port] || '5432')}/#{options[:database]}"
788
+ default_url = "jdbc:postgresql://#{(options[:host] || '127.0.0.1')}:#{(options[:port] || '5432')}/#{options[:database]}"
785
789
  end
786
790
 
787
791
  params = {
@@ -901,7 +905,7 @@ module Buildr #:nodoc:
901
905
  }
902
906
  classpath = options[:classpath] || []
903
907
  xml.tag!('data-source', data_source_options) do |xml|
904
- xml.tag!('synchronize', (options[:synchronize]||'true'))
908
+ xml.tag!('synchronize', (options[:synchronize] || 'true'))
905
909
  xml.tag!('jdbc-driver', options[:driver]) if options[:driver]
906
910
  xml.tag!('jdbc-url', options[:url]) if options[:url]
907
911
  xml.tag!('user-name', options[:username]) if options[:username]
@@ -1002,7 +1006,7 @@ module Buildr #:nodoc:
1002
1006
  end
1003
1007
  end
1004
1008
 
1005
- def add_exploded_ear_artifact(project, options ={})
1009
+ def add_exploded_ear_artifact(project, options = {})
1006
1010
  artifact_name = to_artifact_name(project, options)
1007
1011
 
1008
1012
  add_artifact(artifact_name, 'exploded-ear', build_on_make(options)) do |xml|
@@ -1478,7 +1482,7 @@ module Buildr #:nodoc:
1478
1482
  buildr_project.projects.select { |subp| subp.iml? }.each do |subproject|
1479
1483
  module_path = subproject.base_dir.gsub(/^#{buildr_project.base_dir}\//, '')
1480
1484
  path = "#{module_path}/#{subproject.iml.name}.iml"
1481
- attribs = {:fileurl => "file://$PROJECT_DIR$/#{path}", :filepath => "$PROJECT_DIR$/#{path}"}
1485
+ attribs = { :fileurl => "file://$PROJECT_DIR$/#{path}", :filepath => "$PROJECT_DIR$/#{path}" }
1482
1486
  if subproject.iml.group == true
1483
1487
  attribs[:group] = subproject.parent.name.gsub(':', '/')
1484
1488
  elsif !subproject.iml.group.nil?
@@ -1528,7 +1532,7 @@ module Buildr #:nodoc:
1528
1532
  end
1529
1533
 
1530
1534
  def data_sources_component
1531
- create_composite_component('DataSourceManagerImpl', {:format => 'xml', :hash => '3208837817'}, self.data_sources)
1535
+ create_composite_component('DataSourceManagerImpl', { :format => 'xml', :hash => '3208837817' }, self.data_sources)
1532
1536
  end
1533
1537
 
1534
1538
  def artifacts_component
@@ -1538,6 +1542,9 @@ module Buildr #:nodoc:
1538
1542
  def compiler_configuration_component
1539
1543
  lambda do
1540
1544
  create_component('CompilerConfiguration') do |component|
1545
+ compiler_configuration_options.each_pair do |k, v|
1546
+ component.option :name => k, :value => v
1547
+ end
1541
1548
  component.addNotNullAssertions :enabled => 'false' unless nonnull_assertions?
1542
1549
  component.wildcardResourcePatterns do |xml|
1543
1550
  wildcard_resource_patterns.each do |pattern|
@@ -1554,8 +1561,8 @@ module Buildr #:nodoc:
1554
1561
  disabled = []
1555
1562
  Buildr.projects.each do |prj|
1556
1563
  next unless prj.iml?
1557
- main_processor = !!prj.compile.options[:processor] || prj.compile.options[:processor].nil?
1558
- test_processor = !!prj.test.compile.options[:processor] || prj.test.compile.options[:processor].nil?
1564
+ main_processor = !!prj.compile.options[:processor] || (prj.compile.options[:processor].nil? && !(prj.compile.options[:processor_path] || []).empty?)
1565
+ test_processor = !!prj.test.compile.options[:processor] || (prj.test.compile.options[:processor].nil? && !(prj.test.compile.options[:processor_path] || []).empty?)
1559
1566
  if main_processor || test_processor
1560
1567
  xml.profile(:name => "#{prj.name}", :enabled => true) do
1561
1568
  xml.sourceOutputDir :name => 'generated/processors/main/java' if main_processor
@@ -1597,7 +1604,7 @@ module Buildr #:nodoc:
1597
1604
  resolve_path_from_base(path, '$PROJECT_DIR$')
1598
1605
  end
1599
1606
 
1600
- private
1607
+ private
1601
1608
 
1602
1609
  def default_code_sight_excludes
1603
1610
  %w(
@@ -1717,7 +1724,7 @@ module Buildr #:nodoc:
1717
1724
  ].compact
1718
1725
 
1719
1726
  files.each do |ideafile|
1720
- module_dir = File.dirname(ideafile.filename)
1727
+ module_dir = File.dirname(ideafile.filename)
1721
1728
  idea.enhance do |task|
1722
1729
  mkdir_p module_dir
1723
1730
  info "Writing #{ideafile.filename}"
@@ -23,30 +23,32 @@ module Buildr
23
23
  end
24
24
 
25
25
  after_define do |project|
26
- if project.compile.options.processor?
27
- project.file(project._(:target, :generated, 'processors/main/java'))
28
- project.compile.enhance do
29
- mkdir_p project._(:target, :generated, 'processors/main/java')
26
+ if !!project.compile.options[:processor] || (project.compile.options[:processor].nil? && !(project.compile.options[:processor_path] || []).empty?)
27
+ path = project._(:target, :generated, 'processors/main/java')
28
+ f = project.file(path) do |t|
29
+ mkdir_p t.to_s
30
30
  end
31
+ project.compile.enhance([f])
31
32
  project.compile.options[:other] = [] unless project.compile.options[:other]
32
- project.compile.options[:other] += ['-s', project._(:target, :generated, 'processors/main/java')]
33
- project.iml.main_generated_source_directories << project._(:target, :generated, 'processors/main/java') if project.iml?
33
+ project.compile.options[:other] += ['-s', path]
34
+ project.iml.main_generated_source_directories << path if project.iml?
34
35
 
35
36
  project.clean do
36
- rm_rf project._(:target, :generated, 'processors/main/java')
37
+ rm_rf path
37
38
  end
38
39
  end
39
- if project.test.compile.options.processor?
40
- project.file(project._(:target, :generated, 'processors/test/java'))
41
- project.test.compile.enhance do
42
- mkdir_p project._(:target, :generated, 'processors/test/java')
40
+ if !!project.test.compile.options[:processor] || (project.test.compile.options[:processor].nil? && !(project.test.compile.options[:processor_path] || []).empty?)
41
+ path = project._(:target, :generated, 'processors/test/java')
42
+ f = project.file(path) do |t|
43
+ mkdir_p t.to_s
43
44
  end
45
+ project.test.compile.enhance([f])
44
46
  project.test.compile.options[:other] = [] unless project.test.compile.options[:other]
45
- project.test.compile.options[:other] += ['-s', project._(:target, :generated, 'processors/test/java')]
46
- project.iml.test_generated_source_directories << project._(:target, :generated, 'processors/test/java') if project.iml?
47
+ project.test.compile.options[:other] += ['-s', path]
48
+ project.iml.test_generated_source_directories << path if project.iml?
47
49
 
48
50
  project.clean do
49
- rm_rf project._(:target, :generated, 'processors/test/java')
51
+ rm_rf path
50
52
  end
51
53
  end
52
54
  end
@@ -70,7 +70,7 @@ module Java
70
70
  paths = cp.map do |c|
71
71
  File.directory?(c) && !c.end_with?('/') ? "#{c}/" : c.to_s
72
72
  end
73
- manifest = Buildr::Packaging::Java::Manifest.new([{'Class-Path' => paths.map{|p| URI.encode(p)}.join(" ")}])
73
+ manifest = Buildr::Packaging::Java::Manifest.new([{'Class-Path' => paths.map{|p| CGI.escape(p)}.join(" ")}])
74
74
  tjar = Tempfile.new(%w[javacmd .jar])
75
75
  Zip::OutputStream.open(tjar.path) do |zos|
76
76
  zos.put_next_entry('META-INF/MANIFEST.MF')
@@ -0,0 +1,262 @@
1
+ #
2
+ # Licensed under the Apache License, Version 2.0 (the "License");
3
+ # you may not use this file except in compliance with the License.
4
+ # You may obtain a copy of the License at
5
+ #
6
+ # http://www.apache.org/licenses/LICENSE-2.0
7
+ #
8
+ # Unless required by applicable law or agreed to in writing, software
9
+ # distributed under the License is distributed on an "AS IS" BASIS,
10
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ # See the License for the specific language governing permissions and
12
+ # limitations under the License.
13
+ #
14
+
15
+ require 'net/http'
16
+ require 'net/https'
17
+ require 'json'
18
+
19
+ module Buildr
20
+ class MavenCentral
21
+ class << self
22
+ def define_publish_tasks(options = {})
23
+ candidate_branches = options[:branches] || %w(master)
24
+ desc 'Publish release on maven central'
25
+ task 'mcrt:publish' do
26
+ project = options[:project] || Buildr.projects[0].root_project
27
+ profile_name = options[:profile_name] || (raise ':profile_name not specified when defining tasks')
28
+ username = options[:username] || (raise ':username name not specified when defining tasks')
29
+ password = options[:password] || ENV['MAVEN_CENTRAL_PASSWORD'] || (raise "Unable to locate environment variable with name 'MAVEN_CENTRAL_PASSWORD'")
30
+ MavenCentral.buildr_release(project, profile_name, username, password)
31
+ end
32
+
33
+ desc 'Publish release to maven central iff current HEAD is a tag'
34
+ task 'mcrt:publish_if_tagged' do
35
+ tag = MavenCentral.get_head_tag_if_any
36
+ if tag.nil?
37
+ puts 'Current HEAD is not a tag. Skipping publish step.'
38
+ else
39
+ puts "Current HEAD is a tag: #{tag}"
40
+ if MavenCentral.is_tag_on_candidate_branches?(tag, candidate_branches)
41
+ task('mcrt:publish').invoke
42
+ end
43
+ end
44
+ end
45
+ end
46
+
47
+ def get_head_tag_if_any
48
+ version = `git describe --exact-match --tags 2>&1`
49
+ if 0 == $?.exitstatus && version =~ /^v[0-9]/ && (ENV['TRAVIS_BUILD_ID'].nil? || ENV['TRAVIS_TAG'].to_s != '')
50
+ version.strip
51
+ else
52
+ nil
53
+ end
54
+ end
55
+
56
+ def is_tag_on_branch?(tag, branch)
57
+ output = `git tag --merged #{branch} 2>&1`
58
+ tags = output.split
59
+ tags.include?(tag)
60
+ end
61
+
62
+ def is_tag_on_candidate_branches?(tag, branches)
63
+ sh 'git fetch origin'
64
+ branches.each do |branch|
65
+ if is_tag_on_branch?(tag, branch)
66
+ puts "Tag #{tag} is on branch: #{branch}"
67
+ return true
68
+ elsif is_tag_on_branch?(tag, "origin/#{branch}")
69
+ puts "Tag #{tag} is on branch: origin/#{branch}"
70
+ return true
71
+ else
72
+ puts "Tag #{tag} is not on branches: #{branch} or origin/#{branch}"
73
+ end
74
+ end
75
+ false
76
+ end
77
+
78
+ def buildr_release(project, profile_name, username, password)
79
+ release_to_url = Buildr.repositories.release_to[:url]
80
+ release_to_username = Buildr.repositories.release_to[:username]
81
+ release_to_password = Buildr.repositories.release_to[:password]
82
+
83
+ begin
84
+ Buildr.repositories.release_to[:url] = 'https://oss.sonatype.org/service/local/staging/deploy/maven2'
85
+ Buildr.repositories.release_to[:username] = username
86
+ Buildr.repositories.release_to[:password] = password
87
+
88
+ project.task(':package').invoke
89
+
90
+ r = MavenCentral.new
91
+ r.username = username
92
+ r.password = password
93
+ r.user_agent = "Buildr-#{Buildr::VERSION}"
94
+ while r.get_staging_repositories(profile_name, false).size != 0
95
+ puts 'Another project currently staging. Waiting for other repository to complete. Please visit the website https://oss.sonatype.org/index.html#stagingRepositories to view the other staging attempts.'
96
+ sleep 1
97
+ end
98
+ puts "Beginning upload to staging repository #{profile_name}"
99
+
100
+ project.task(':upload').invoke
101
+
102
+ r.release_sole_auto_staging(profile_name)
103
+ ensure
104
+ Buildr.repositories.release_to[:url] = release_to_url
105
+ Buildr.repositories.release_to[:username] = release_to_username
106
+ Buildr.repositories.release_to[:password] = release_to_password
107
+ end
108
+ end
109
+ end
110
+
111
+ attr_writer :username
112
+
113
+ def username
114
+ @username || (raise 'Username not yet specified')
115
+ end
116
+
117
+ attr_writer :password
118
+
119
+ def password
120
+ @password || (raise 'Password not yet specified')
121
+ end
122
+
123
+ attr_writer :user_agent
124
+
125
+ def user_agent
126
+ @user_agent || "Ruby-#{RUBY_VERSION}"
127
+ end
128
+
129
+ def get_staging_repositories(profile_name, ignore_transitioning_repositories = true)
130
+ result = get_request('https://oss.sonatype.org/service/local/staging/profile_repositories')
131
+ result = JSON.parse(result)
132
+ result['data'].select do |repo|
133
+ repo['profileName'] == profile_name &&
134
+ repo['userId'] == self.username &&
135
+ repo['userAgent'] == self.user_agent &&
136
+ (!ignore_transitioning_repositories || !repo['transitioning']) &&
137
+ get_my_ip_addresses.any? { |a| a == repo['ipAddress'] }
138
+ end
139
+ end
140
+
141
+ def get_my_ip_addresses
142
+ addresses = Socket.ip_address_list.collect { |a| a.ip_address.to_s }
143
+ commands = [
144
+ "dig +short myip.opendns.com @resolver1.opendns.com",
145
+ "curl ifconfig.me",
146
+ "curl icanhazip.com",
147
+ "curl ipecho.net/plain",
148
+ "curl ifconfig.co",
149
+ "dig TXT +short o-o.myaddr.l.google.com @ns1.google.com | awk -F'\"' '{ print $2 }'"
150
+ ]
151
+ commands.each do |cmd|
152
+ begin
153
+ addresses << `#{cmd}`.strip
154
+ rescue Exception
155
+ # ignored
156
+ end
157
+ end
158
+ urls = %w[http://www.myexternalip.com/raw https://diagnostic.opendns.com/myip]
159
+ urls.each do |url|
160
+ begin
161
+ addresses << Net::HTTP.get(URI(url)).strip
162
+ rescue Exception
163
+ # ignored
164
+ end
165
+ end
166
+ begin
167
+ addresses << JSON.parse(Net::HTTP.get(URI('https://api.ipify.org?format=json')))['ip']
168
+ rescue Exception
169
+ # ignored
170
+ end
171
+ addresses.sort.uniq
172
+ end
173
+
174
+ def close_repository(repository_id, description)
175
+ post_request('https://oss.sonatype.org/service/local/staging/bulk/close',
176
+ JSON.pretty_generate('data' => { 'description' => description, 'stagedRepositoryIds' => [repository_id] }))
177
+ end
178
+
179
+ def promote_repository(repository_id, description)
180
+ post_request('https://oss.sonatype.org/service/local/staging/bulk/promote',
181
+ JSON.pretty_generate('data' => { 'autoDropAfterRelease' => true,
182
+ 'description' => description,
183
+ 'stagedRepositoryIds' => [repository_id] }))
184
+ end
185
+
186
+ def drop_repository(repository_id, description)
187
+ post_request('https://oss.sonatype.org/service/local/staging/bulk/drop',
188
+ JSON.pretty_generate('data' => { 'description' => description, 'stagedRepositoryIds' => [repository_id] }))
189
+ end
190
+
191
+ def release_sole_auto_staging(profile_name)
192
+ candidates = get_staging_repositories(profile_name)
193
+ if candidates.empty?
194
+ raise 'Release process unable to find any staging repositories.'
195
+ elsif 1 != candidates.size
196
+ raise 'Release process found multiple staging repositories that could be the release just uploaded. Please visit the website https://oss.sonatype.org/index.html#stagingRepositories and manually complete the release.'
197
+ else
198
+ candidate = candidates[0]
199
+ puts "Requesting close of staging repository #{profile_name}:#{candidate['repositoryId']}"
200
+ begin
201
+ close_repository(candidate['repositoryId'], "Closing repository for #{profile_name}")
202
+ rescue Exception => e
203
+ puts "#{e.class.name}: #{e.message}"
204
+ puts e.backtrace.join("\n")
205
+ raise 'Failed to close repository. It is likely that the release does not conform to Maven Central release requirements. Please visit the website https://oss.sonatype.org/index.html#stagingRepositories and manually complete the release.'
206
+ end
207
+ while get_staging_repositories(profile_name).size == 0
208
+ puts 'Waiting for repository to close...'
209
+ sleep 1
210
+ end
211
+ puts "Requesting promotion of staging repository #{profile_name}:#{candidate['repositoryId']}"
212
+ begin
213
+ promote_repository(candidate['repositoryId'], "Promoting repository for #{profile_name}")
214
+ rescue Exception => e
215
+ puts "#{e.class.name}: #{e.message}"
216
+ puts e.backtrace.join("\n")
217
+ raise 'Failed to promote repository. Please visit the website https://oss.sonatype.org/index.html#stagingRepositories and manually complete the release.'
218
+ end
219
+ repositories = get_staging_repositories(profile_name, false)
220
+ while repositories.size == 1
221
+ puts 'Waiting for repository to be promoted...'
222
+ sleep 1
223
+ if repositories[0]['notifications'] != 0
224
+ raise 'Failed to promote repository. Please visit the website https://oss.sonatype.org/index.html#stagingRepositories and manually complete the release.'
225
+ end
226
+ repositories = get_staging_repositories(profile_name, false)
227
+ end
228
+ end
229
+ end
230
+
231
+ private
232
+
233
+ def create_http(uri)
234
+ http = Net::HTTP.new(uri.host, uri.port)
235
+ http.use_ssl = true
236
+ http.verify_mode = OpenSSL::SSL::VERIFY_PEER
237
+ http
238
+ end
239
+
240
+ def setup_standard_request(request)
241
+ request['Accept'] = 'application/json,application/vnd.siesta-error-v1+json,application/vnd.siesta-validation-errors-v1+json'
242
+ request.basic_auth(self.username, self.password)
243
+ request.add_field('User-Agent', self.user_agent)
244
+ end
245
+
246
+ def get_request(url)
247
+ uri = URI.parse(url)
248
+ request = Net::HTTP::Get.new(uri.request_uri)
249
+ setup_standard_request(request)
250
+ create_http(uri).request(request).body
251
+ end
252
+
253
+ def post_request(url, content)
254
+ uri = URI.parse(url)
255
+ request = Net::HTTP::Post.new(uri.request_uri)
256
+ setup_standard_request(request)
257
+ request.add_field('Content-Type', 'application/json')
258
+ request.body = content
259
+ create_http(uri).request(request).body
260
+ end
261
+ end
262
+ end
@@ -246,9 +246,8 @@ module Buildr #:nodoc:
246
246
  # Username/password may be part of URI, or separate entities.
247
247
  uri = URI.parse(upload_to[:url].clone)
248
248
  uri.path = uri.path + '/' unless uri.path[-1] == '/'
249
- to_escape = "!\"\#$%&'()*+,-./:;<=>?@{}|~`'"
250
- uri.user = URI.encode(upload_to[:username], to_escape) if upload_to[:username]
251
- uri.password = URI.encode(upload_to[:password], to_escape) if upload_to[:password]
249
+ uri.user = CGI.escape(upload_to[:username]) if upload_to[:username]
250
+ uri.password = CGI.escape(upload_to[:password]) if upload_to[:password]
252
251
 
253
252
  path = group.gsub('.', '/') + "/#{id}/#{version}/#{upload_name}"
254
253
 
@@ -14,5 +14,5 @@
14
14
  # the License.
15
15
 
16
16
  module Buildr #:nodoc:
17
- VERSION = '1.5.10'.freeze
17
+ VERSION = '1.5.15'.freeze
18
18
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: realityforge-buildr
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.5.10
4
+ version: 1.5.15
5
5
  platform: ruby
6
6
  authors:
7
7
  - Apache Buildr
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-03-19 00:00:00.000000000 Z
11
+ date: 2021-03-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rake
@@ -220,6 +220,7 @@ files:
220
220
  - lib/buildr/java/doc.rb
221
221
  - lib/buildr/java/packaging.rb
222
222
  - lib/buildr/java/pom.rb
223
+ - lib/buildr/java/publish.rb
223
224
  - lib/buildr/java/test_result.rb
224
225
  - lib/buildr/java/tests.rb
225
226
  - lib/buildr/packaging/archive.rb