blob: ac0c77391d70ea0994b2d2dbb3616a24da136ab3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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
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
|
# frozen_string_literal: true
module Packages
module Maven
class FindOrCreatePackageService < BaseService
SNAPSHOT_TERM = '-SNAPSHOT'
MAX_FILE_NAME_LENGTH = 5000
def execute
return ServiceResponse.error(message: 'File name is too long') if file_name_too_long?
package =
::Packages::Maven::PackageFinder.new(current_user, project, path: path)
.execute
unless Namespace::PackageSetting.duplicates_allowed?(package)
return ServiceResponse.error(message: 'Duplicate package is not allowed') if target_package_is_duplicate?(package)
end
unless package
# Maven uploads several files during `mvn deploy` in next order:
# - my-company/my-app/1.0-SNAPSHOT/my-app.jar
# - my-company/my-app/1.0-SNAPSHOT/my-app.pom
# - my-company/my-app/1.0-SNAPSHOT/maven-metadata.xml
# - my-company/my-app/maven-metadata.xml
#
# The last xml file does not have VERSION in URL because it contains
# information about all versions. When uploading such file, we create
# a package with a version set to `nil`. The xml file with a version
# is only created and uploaded for snapshot versions.
#
# Gradle has a different upload order:
# - my-company/my-app/1.0-SNAPSHOT/maven-metadata.xml
# - my-company/my-app/1.0-SNAPSHOT/my-app.jar
# - my-company/my-app/1.0-SNAPSHOT/my-app.pom
# - my-company/my-app/maven-metadata.xml
#
# The first upload has to create the proper package (the one with the version set).
if file_name == Packages::Maven::Metadata.filename && !snapshot_version?
package_name = path
version = nil
else
package_name, _, version = path.rpartition('/')
end
package_params = {
name: package_name,
path: path,
status: params[:status],
version: version
}
package =
::Packages::Maven::CreatePackageService.new(project, current_user, package_params)
.execute
end
package.create_build_infos!(params[:build])
ServiceResponse.success(payload: { package: package })
end
private
def file_name_too_long?
return false unless file_name
file_name.size > MAX_FILE_NAME_LENGTH
end
def target_package_is_duplicate?(package)
# duplicate metadata files can be uploaded multiple times
return false if package.version.nil?
existing_file_names = strip_snapshot_parts(
package.package_files
.map(&:file_name)
.compact
)
published_file_name = strip_snapshot_parts_from(file_name)
existing_file_names.include?(published_file_name)
end
def strip_snapshot_parts(file_names)
return file_names unless snapshot_version?
Array.wrap(file_names).map { |f| strip_snapshot_parts_from(f) }
end
def strip_snapshot_parts_from(file_name)
return file_name unless snapshot_version?
return unless file_name
match_data = file_name.match(Gitlab::Regex::Packages::MAVEN_SNAPSHOT_DYNAMIC_PARTS)
if match_data
file_name.gsub(match_data.captures.last, "")
else
file_name
end
end
def snapshot_version?
path&.ends_with?(SNAPSHOT_TERM)
end
def path
params[:path]
end
def file_name
params[:file_name]
end
end
end
end
|