Added projects with tmp builds
This commit is contained in:
5
Gemfile
5
Gemfile
@@ -17,9 +17,7 @@ gem "inifile", "~> 3.0"
|
||||
|
||||
gem "carrierwave", "~> 3.1"
|
||||
|
||||
gem "data_mapper", "~> 1.2"
|
||||
|
||||
gem "json", "~> 1.8"
|
||||
gem "json", "~> 2.5"
|
||||
|
||||
gem "stringio", "~> 3.1"
|
||||
|
||||
@@ -38,3 +36,4 @@ gem "ffi", "~> 1.17"
|
||||
gem "ptools", "~> 1.5"
|
||||
|
||||
gem "ostruct", "~> 0.6.1"
|
||||
|
||||
|
||||
156
Gemfile.lock
156
Gemfile.lock
@@ -1,16 +1,16 @@
|
||||
GEM
|
||||
remote: https://rubygems.org/
|
||||
specs:
|
||||
activemodel (8.0.1)
|
||||
activesupport (= 8.0.1)
|
||||
activesupport (8.0.1)
|
||||
activemodel (8.1.1)
|
||||
activesupport (= 8.1.1)
|
||||
activesupport (8.1.1)
|
||||
base64
|
||||
benchmark (>= 0.3)
|
||||
bigdecimal
|
||||
concurrent-ruby (~> 1.0, >= 1.3.1)
|
||||
connection_pool (>= 2.2.5)
|
||||
drb
|
||||
i18n (>= 1.6, < 2)
|
||||
json
|
||||
logger (>= 1.4.2)
|
||||
minitest (>= 5.1)
|
||||
securerandom (>= 0.3)
|
||||
@@ -18,13 +18,9 @@ GEM
|
||||
uri (>= 0.13.1)
|
||||
addressable (2.8.7)
|
||||
public_suffix (>= 2.0.2, < 7.0)
|
||||
base64 (0.2.0)
|
||||
bcrypt (3.1.20)
|
||||
bcrypt-ruby (3.1.5)
|
||||
bcrypt (>= 3.1.3)
|
||||
benchmark (0.4.0)
|
||||
bigdecimal (3.1.9)
|
||||
carrierwave (3.1.1)
|
||||
base64 (0.3.0)
|
||||
bigdecimal (3.3.1)
|
||||
carrierwave (3.1.2)
|
||||
activemodel (>= 6.0.0)
|
||||
activesupport (>= 6.0.0)
|
||||
addressable (~> 2.6)
|
||||
@@ -32,130 +28,82 @@ GEM
|
||||
marcel (~> 1.0.0)
|
||||
ssrf_filter (~> 1.0)
|
||||
concurrent-ruby (1.3.5)
|
||||
connection_pool (2.5.0)
|
||||
data_mapper (1.2.0)
|
||||
dm-aggregates (~> 1.2.0)
|
||||
dm-constraints (~> 1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-migrations (~> 1.2.0)
|
||||
dm-serializer (~> 1.2.0)
|
||||
dm-timestamps (~> 1.2.0)
|
||||
dm-transactions (~> 1.2.0)
|
||||
dm-types (~> 1.2.0)
|
||||
dm-validations (~> 1.2.0)
|
||||
dm-aggregates (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-constraints (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-core (1.2.1)
|
||||
addressable (~> 2.3)
|
||||
dm-migrations (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-serializer (1.2.2)
|
||||
dm-core (~> 1.2.0)
|
||||
fastercsv (~> 1.5)
|
||||
json (~> 1.6)
|
||||
json_pure (~> 1.6)
|
||||
multi_json (~> 1.0)
|
||||
dm-timestamps (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-transactions (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
dm-types (1.2.2)
|
||||
bcrypt-ruby (~> 3.0)
|
||||
dm-core (~> 1.2.0)
|
||||
fastercsv (~> 1.5)
|
||||
json (~> 1.6)
|
||||
multi_json (~> 1.0)
|
||||
stringex (~> 1.4)
|
||||
uuidtools (~> 2.1)
|
||||
dm-validations (1.2.0)
|
||||
dm-core (~> 1.2.0)
|
||||
drb (2.2.1)
|
||||
fastercsv (1.5.5)
|
||||
ffi (1.17.1)
|
||||
ffi (1.17.1-aarch64-linux-gnu)
|
||||
ffi (1.17.1-aarch64-linux-musl)
|
||||
ffi (1.17.1-arm-linux-gnu)
|
||||
ffi (1.17.1-arm-linux-musl)
|
||||
ffi (1.17.1-arm64-darwin)
|
||||
ffi (1.17.1-x86-linux-gnu)
|
||||
ffi (1.17.1-x86-linux-musl)
|
||||
ffi (1.17.1-x86_64-darwin)
|
||||
ffi (1.17.1-x86_64-linux-gnu)
|
||||
ffi (1.17.1-x86_64-linux-musl)
|
||||
connection_pool (2.5.4)
|
||||
drb (2.2.3)
|
||||
ffi (1.17.2-aarch64-linux-gnu)
|
||||
ffi (1.17.2-aarch64-linux-musl)
|
||||
ffi (1.17.2-arm-linux-gnu)
|
||||
ffi (1.17.2-arm-linux-musl)
|
||||
ffi (1.17.2-arm64-darwin)
|
||||
ffi (1.17.2-x86-linux-gnu)
|
||||
ffi (1.17.2-x86-linux-musl)
|
||||
ffi (1.17.2-x86_64-darwin)
|
||||
ffi (1.17.2-x86_64-linux-gnu)
|
||||
ffi (1.17.2-x86_64-linux-musl)
|
||||
i18n (1.14.7)
|
||||
concurrent-ruby (~> 1.0)
|
||||
image_processing (1.14.0)
|
||||
mini_magick (>= 4.9.5, < 6)
|
||||
ruby-vips (>= 2.0.17, < 3)
|
||||
inifile (3.0.0)
|
||||
json (1.8.6)
|
||||
json_pure (1.8.6)
|
||||
logger (1.6.6)
|
||||
json (2.15.2)
|
||||
logger (1.7.0)
|
||||
marcel (1.0.4)
|
||||
mini_magick (5.1.2)
|
||||
benchmark
|
||||
mini_magick (5.3.1)
|
||||
logger
|
||||
mini_portile2 (2.8.8)
|
||||
minitest (5.25.4)
|
||||
multi_json (1.15.0)
|
||||
mustermann (3.0.3)
|
||||
minitest (5.26.0)
|
||||
mustermann (3.0.4)
|
||||
ruby2_keywords (~> 0.0.1)
|
||||
nio4r (2.7.4)
|
||||
ostruct (0.6.1)
|
||||
nio4r (2.7.5)
|
||||
ostruct (0.6.3)
|
||||
ptools (1.5.0)
|
||||
public_suffix (6.0.1)
|
||||
puma (6.6.0)
|
||||
public_suffix (6.0.2)
|
||||
puma (6.6.1)
|
||||
nio4r (~> 2.0)
|
||||
rack (3.1.10)
|
||||
rack-protection (4.1.1)
|
||||
rack (3.2.4)
|
||||
rack-protection (4.2.1)
|
||||
base64 (>= 0.1.0)
|
||||
logger (>= 1.6.0)
|
||||
rack (>= 3.0.0, < 4)
|
||||
rack-session (2.1.0)
|
||||
rack-session (2.1.1)
|
||||
base64 (>= 0.1.0)
|
||||
rack (>= 3.0.0)
|
||||
rackup (2.2.1)
|
||||
rack (>= 3)
|
||||
ruby-vips (2.2.3)
|
||||
ruby-vips (2.2.5)
|
||||
ffi (~> 1.12)
|
||||
logger
|
||||
ruby2_keywords (0.0.5)
|
||||
rugged (1.9.0)
|
||||
securerandom (0.4.1)
|
||||
sequel (5.89.0)
|
||||
sequel (5.98.0)
|
||||
bigdecimal
|
||||
shotgun (0.9.2)
|
||||
rack (>= 1.0)
|
||||
sinatra (4.1.1)
|
||||
sinatra (4.2.1)
|
||||
logger (>= 1.6.0)
|
||||
mustermann (~> 3.0)
|
||||
rack (>= 3.0.0, < 4)
|
||||
rack-protection (= 4.1.1)
|
||||
rack-protection (= 4.2.1)
|
||||
rack-session (>= 2.0.0, < 3)
|
||||
tilt (~> 2.0)
|
||||
sqlite (1.0.2)
|
||||
sqlite3 (2.5.0)
|
||||
mini_portile2 (~> 2.8.0)
|
||||
sqlite3 (2.5.0-aarch64-linux-gnu)
|
||||
sqlite3 (2.5.0-aarch64-linux-musl)
|
||||
sqlite3 (2.5.0-arm-linux-gnu)
|
||||
sqlite3 (2.5.0-arm-linux-musl)
|
||||
sqlite3 (2.5.0-arm64-darwin)
|
||||
sqlite3 (2.5.0-x86-linux-gnu)
|
||||
sqlite3 (2.5.0-x86-linux-musl)
|
||||
sqlite3 (2.5.0-x86_64-darwin)
|
||||
sqlite3 (2.5.0-x86_64-linux-gnu)
|
||||
sqlite3 (2.5.0-x86_64-linux-musl)
|
||||
ssrf_filter (1.2.0)
|
||||
stringex (1.5.1)
|
||||
stringio (3.1.3)
|
||||
tilt (2.6.0)
|
||||
sqlite3 (2.7.4-aarch64-linux-gnu)
|
||||
sqlite3 (2.7.4-aarch64-linux-musl)
|
||||
sqlite3 (2.7.4-arm-linux-gnu)
|
||||
sqlite3 (2.7.4-arm-linux-musl)
|
||||
sqlite3 (2.7.4-arm64-darwin)
|
||||
sqlite3 (2.7.4-x86-linux-gnu)
|
||||
sqlite3 (2.7.4-x86-linux-musl)
|
||||
sqlite3 (2.7.4-x86_64-darwin)
|
||||
sqlite3 (2.7.4-x86_64-linux-gnu)
|
||||
sqlite3 (2.7.4-x86_64-linux-musl)
|
||||
ssrf_filter (1.3.0)
|
||||
stringio (3.1.7)
|
||||
tilt (2.6.1)
|
||||
tzinfo (2.0.6)
|
||||
concurrent-ruby (~> 1.0)
|
||||
uri (1.0.2)
|
||||
uuidtools (2.2.0)
|
||||
uri (1.1.1)
|
||||
|
||||
PLATFORMS
|
||||
aarch64-linux-gnu
|
||||
@@ -163,7 +111,6 @@ PLATFORMS
|
||||
arm-linux-gnu
|
||||
arm-linux-musl
|
||||
arm64-darwin
|
||||
ruby
|
||||
x86-linux-gnu
|
||||
x86-linux-musl
|
||||
x86_64-darwin
|
||||
@@ -172,10 +119,9 @@ PLATFORMS
|
||||
|
||||
DEPENDENCIES
|
||||
carrierwave (~> 3.1)
|
||||
data_mapper (~> 1.2)
|
||||
ffi (~> 1.17)
|
||||
inifile (~> 3.0)
|
||||
json (~> 1.8)
|
||||
json (~> 2.5)
|
||||
ostruct (~> 0.6.1)
|
||||
ptools (~> 1.5)
|
||||
puma (~> 6.6)
|
||||
@@ -189,4 +135,4 @@ DEPENDENCIES
|
||||
stringio (~> 3.1)
|
||||
|
||||
BUNDLED WITH
|
||||
2.6.3
|
||||
2.7.2
|
||||
|
||||
6
app.rb
6
app.rb
@@ -343,6 +343,7 @@ get "/prjcreate" do
|
||||
@local_list = result[:local]
|
||||
@old_nopublic = session[:prj_old_nopublic]
|
||||
@error_data = session[:prjcreate_error]
|
||||
@old_tmpbld = session[:prj_old_tmpbld]
|
||||
session[:prjcreate_error] = nil
|
||||
erb :prjcrt
|
||||
end
|
||||
@@ -352,12 +353,13 @@ post "/prjcreate" do
|
||||
session[:prj_old_description] = params["description"]
|
||||
session[:prj_old_list] = params["conflist"]
|
||||
session[:prj_old_nopublic] = params["nopublic"]
|
||||
session[:prj_old_tmpbld] = params["tmpbld"]
|
||||
if params["projname"].nil? || params["description"].nil? || params["projname"].strip == "" || params["description"].strip == "" || params["conflist"].nil? || params["conflist"].strip == ""
|
||||
session[:rcpcreate_error] = "Имя проекта, описание и окружение сборки не должны быть пустыми"
|
||||
redirect "/prjcreate"
|
||||
else
|
||||
prj = ProjectsActions.new(cfg.get_projects_path, db)
|
||||
result = prj.create_project(params["projname"], params["description"], params["conflist"], params["nopublic"])
|
||||
result = prj.create_project(params["projname"], params["description"], params["conflist"], params["nopublic"], params["tmpbld"])
|
||||
if result != 0
|
||||
session[:prjcreate_error] = prj.error
|
||||
redirect "/prjcreate"
|
||||
@@ -366,6 +368,7 @@ post "/prjcreate" do
|
||||
session[:prj_old_description] = nil
|
||||
session[:prj_old_list] = nil
|
||||
session[:prj_old_nopublic] = nil
|
||||
session[:prj_old_tmpbld] = nil
|
||||
redirect "/projs"
|
||||
end
|
||||
end
|
||||
@@ -395,6 +398,7 @@ get "/prjedit/:id" do
|
||||
@proj_descr = prj_info[:descr]
|
||||
@proj_id = prj_info[:id]
|
||||
@proj_public = prj_info[:public]
|
||||
@proj_tmpbuild = prj_info[:tmpstpbuild]
|
||||
repo_lst = repo.getrepos
|
||||
proj_repo_list = prj.get_project_gits(prj_info[:id], repo)
|
||||
@repo_list = repo_lst.reject do |item|
|
||||
|
||||
@@ -146,7 +146,7 @@ class DBase
|
||||
Projects[id]
|
||||
end
|
||||
|
||||
def proj_create(proj_name, proj_descr, nopublic)
|
||||
def proj_create(proj_name, proj_descr, nopublic, tmpbld)
|
||||
@error = nil
|
||||
data = Projects.where(projname: proj_name).first
|
||||
if data.nil?
|
||||
@@ -154,7 +154,11 @@ class DBase
|
||||
unless nopublic.nil?
|
||||
public_proj = 0
|
||||
end
|
||||
id = Projects.insert(projname: proj_name, descr: proj_descr, public: public_proj)
|
||||
tmpbld_proj = 1
|
||||
if tmpbld.nil?
|
||||
tmpbld_proj = 0
|
||||
end
|
||||
id = Projects.insert(projname: proj_name, descr: proj_descr, public: public_proj, tmpstpbuild: tmpbld_proj)
|
||||
@last_id = id
|
||||
else
|
||||
@error = "Данный проект уже существует"
|
||||
|
||||
@@ -4,6 +4,7 @@ require "fileutils"
|
||||
require "logger"
|
||||
require_relative "repomanage"
|
||||
require "digest"
|
||||
require "date"
|
||||
|
||||
BUILD_STRUCTURE = {
|
||||
:SRC => "src",
|
||||
@@ -13,9 +14,9 @@ BUILD_STRUCTURE = {
|
||||
}
|
||||
|
||||
class MockManager
|
||||
attr :path, :config, :error, :last_status, :last_pid, :prep_dir, :db, :resultpath, :process_log, :repo_path, :git_path, :build_id, :log, :recips, :spec, :repo_lock, :git_id
|
||||
attr :path, :config, :error, :last_status, :last_pid, :prep_dir, :db, :resultpath, :process_log, :repo_path, :git_path, :build_id, :log, :recips, :spec, :repo_lock, :git_id, :tmp_bld
|
||||
|
||||
def initialize(path, config, cfg_counter_path, db, result_path, repo_path, git_path, build_id, recips, spec_file, repo_lock, git_id)
|
||||
def initialize(path, config, cfg_counter_path, db, result_path, repo_path, git_path, build_id, recips, spec_file, repo_lock, git_id, tmp_bld)
|
||||
@error = nil
|
||||
unless File.exist? (path)
|
||||
Dir.mkdir(path)
|
||||
@@ -32,6 +33,7 @@ class MockManager
|
||||
@spec = spec_file
|
||||
@repo_lock = repo_lock
|
||||
@git_id = git_id
|
||||
@tmp_bld = tmp_bld
|
||||
|
||||
File.open(cfg_counter_path, "r+") do |f|
|
||||
f.flock(File::LOCK_EX)
|
||||
@@ -110,6 +112,31 @@ class MockManager
|
||||
@log.info("Подготовка SRCRPM")
|
||||
spec_file = File.join(@tmp_src, @spec)
|
||||
if File.exist?(spec_file)
|
||||
if @tmp_bld
|
||||
dt = DateTime.now
|
||||
bld_id = @build_id.to_i
|
||||
bld_str = "%010d" % bld_id
|
||||
dt_str = dt.strftime("%Y%m%d_#{bld_str}")
|
||||
cmd_args = %Q(/usr/bin/rpm -q --specfile #{spec_file} --queryformat "%{RELEASE}")
|
||||
@log.debug(cmd_args)
|
||||
cmd = Runner.new(cmd_args, @log)
|
||||
cmd.run
|
||||
if cmd.exit_status == 0
|
||||
res = "#{cmd.stdout}.#{dt_str}"
|
||||
line_array = []
|
||||
File.readlines(spec_file).each do |line|
|
||||
if line =~ /^[\t ]*[Rr]elease:/
|
||||
line = "Release: #{res}"
|
||||
end
|
||||
line_array << line
|
||||
end
|
||||
File.open(spec_file, "w") do |f|
|
||||
line_array.each do |line|
|
||||
f.puts(line)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
Dir.chdir(@tmp_src) do
|
||||
cmd_args = %Q(/usr/bin/mock -r "#{@config}" --buildsrpm --spec "#{spec_file}" --sources "#{@tmp_src}" --resultdir "#{File.join(@prep_dir, BUILD_STRUCTURE[:RESULT_SRPM])}" --isolation=simple --disable-plugin=ccache)
|
||||
@log.debug(cmd_args)
|
||||
|
||||
@@ -145,7 +145,7 @@ class ProjectsActions
|
||||
generate_linked_repos(id, proj_path, proj_name, prj_incl_path)
|
||||
end
|
||||
|
||||
def create_project(name, description, configuration, nopublic)
|
||||
def create_project(name, description, configuration, nopublic, tmpbld)
|
||||
@error = nil
|
||||
ret_val = 0
|
||||
project_name = sanitize_rcptname(name)
|
||||
@@ -163,7 +163,7 @@ class ProjectsActions
|
||||
end
|
||||
if File.exist?(configuration)
|
||||
generate_config(nil, configuration, fname, project_name)
|
||||
@error = @db.proj_create(project_name, description, nopublic)
|
||||
@error = @db.proj_create(project_name, description, nopublic, tmpbld)
|
||||
if @error.nil?
|
||||
created = true
|
||||
end
|
||||
@@ -317,7 +317,10 @@ class ProjectsActions
|
||||
build_id = @db.last_id
|
||||
f.puts(build_id)
|
||||
f.flush
|
||||
mock = MockManager.new(prepare_path, get_project_config(prj_id), counter_file, @db, build_path, repo_path, git_source, build_id, prep_script, spec_file, repo_lock, git_id)
|
||||
proj_info = get_project(prj_id)
|
||||
tmp_bld = false
|
||||
tmp_bld = true if proj_info[:tmpstpbuild].to_i != 0
|
||||
mock = MockManager.new(prepare_path, get_project_config(prj_id), counter_file, @db, build_path, repo_path, git_source, build_id, prep_script, spec_file, repo_lock, git_id, tmp_bld)
|
||||
bld_id = build_id
|
||||
@db.update_build_task_error_log(build_id, mock.get_build_process_log)
|
||||
mock.build_task
|
||||
|
||||
9
db/migrations/202511040000000_aletrtables.rb
Normal file
9
db/migrations/202511040000000_aletrtables.rb
Normal file
@@ -0,0 +1,9 @@
|
||||
require "sequel"
|
||||
|
||||
Sequel.migration do
|
||||
change do
|
||||
alter_table(:projects) do
|
||||
add_column :tmpstpbuild, Integer, default: 0
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -23,6 +23,14 @@
|
||||
<% end %>
|
||||
<label class="form-check-label" for="nopublic">Не публиковать отладочные пакеты и исходные коды</label>
|
||||
</div>
|
||||
<div class="form-check form-switch">
|
||||
<% if @old_tmpbld.nil? %>
|
||||
<input class="form-check-input" type="checkbox" role="switch" id="tmpbld" name="tmpbld" vlaue="tmpbld">
|
||||
<% else %>
|
||||
<input class="form-check-input" type="checkbox" role="switch" id="tmpbld" name="tmpbld" vlaue="tmpbld" checked>
|
||||
<% end %>
|
||||
<label class="form-check-label" for="tmpbld">Добавлять к версии пакетов дату и ID сборки</label>
|
||||
</div>
|
||||
<div class="mb-3">
|
||||
<label for="conflist" class="form-label">Выберите конфигурацию окружения сборки для проекта</label>
|
||||
<div class="conflist">
|
||||
|
||||
@@ -33,6 +33,13 @@
|
||||
Запрещена публикация пакетов с исходными кодами
|
||||
<% end %>
|
||||
</div>
|
||||
<div class="pb-2">
|
||||
<% if @proj_tmpbuild == 1 %>
|
||||
Сборка с добавлением даты и идентификатора
|
||||
<% else %>
|
||||
Обычная сборка пакетов
|
||||
<% end %>
|
||||
</div>
|
||||
<div class="list-group">
|
||||
<a href="/prjcfg/<%= ERB::Util.url_encode(@proj_id) %>" class="list-group-item list-group-item-action list-group-item-dark icon-link"><i
|
||||
class="bi bi-pen"></i><span class="ms-2">Редактировать
|
||||
|
||||
Reference in New Issue
Block a user