5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2024-11-26 00:56:21 +00:00

Merge branch 'issue-14540' into 'rails'

feat: soportar varias instancias de distributed press #14540

See merge request sutty/sutty!224
This commit is contained in:
fauno 2024-05-02 19:10:17 +00:00
commit bf0a0494cd
3 changed files with 23 additions and 7 deletions

View file

@ -12,7 +12,7 @@ require 'distributed_press/v1/client/site'
# Al ser publicado, envía los archivos en un tarball y actualiza la # Al ser publicado, envía los archivos en un tarball y actualiza la
# información. # información.
class DeployDistributedPress < Deploy class DeployDistributedPress < Deploy
store :values, accessors: %i[hostname remote_site_id remote_info], coder: JSON store :values, accessors: %i[hostname remote_site_id remote_info distributed_press_publisher_id], coder: JSON
before_create :create_remote_site! before_create :create_remote_site!
before_destroy :delete_remote_site! before_destroy :delete_remote_site!
@ -95,12 +95,14 @@ class DeployDistributedPress < Deploy
# El cliente de la API # El cliente de la API
# #
# TODO: cuando soportemos más, tiene que haber una relación entre
# DeployDistributedPress y DistributedPressPublisher.
#
# @return [DistributedPressPublisher] # @return [DistributedPressPublisher]
def publisher def publisher
@publisher ||= DistributedPressPublisher.last @publisher ||=
if distributed_press_publisher_id
DistributedPressPublisher.find(distributed_press_publisher_id)
else
DistributedPressPublisher.find_by_default(true)
end
end end
# El cliente para actualizar el sitio # El cliente para actualizar el sitio

View file

@ -13,8 +13,8 @@ class DistributedPressPublisher < ApplicationRecord
# @return [IO] # @return [IO]
attr_reader :logger_out attr_reader :logger_out
# La instancia es única # La instancia es necesaria pero no única
validates_uniqueness_of :instance validates_presence_of :instance
# El token es necesario # El token es necesario
validates_presence_of :token validates_presence_of :token

View file

@ -0,0 +1,14 @@
# frozen_string_literal: true
# Una instancia es la instancia por defecto
class AddDefaultToDistributedPressPublisher < ActiveRecord::Migration[6.1]
def up
add_column :distributed_press_publishers, :default, :boolean, default: false
DistributedPressPublisher.last&.update(default: true)
end
def down
remove_column :distributed_press_publishers, :default
end
end