60 lines
2.7 KiB
Ruby
60 lines
2.7 KiB
Ruby
module JamRuby
|
|
class IcecastUserAuthentication < ActiveRecord::Base
|
|
|
|
attr_accessible :authentication_type, :filename, :allow_duplicate_users, :mount_add, :mount_remove, :listener_add,
|
|
:listener_remove, :unused_username, :unused_pass, :auth_header, :timelimit_header, as: :admin
|
|
|
|
has_one :mount, class_name: 'JamRuby::IcecastMount', inverse_of: :authentication, :foreign_key => 'authentication_id'
|
|
|
|
validates :authentication_type, presence: true, :inclusion => {:in => ["url", "htpasswd"]}
|
|
validates :allow_duplicate_users, :inclusion => {:in => [0, 1]}, if: :htpasswd_auth?
|
|
validates :unused_username, length: {minimum: 5}, if: :url_auth_and_user_present?
|
|
validates :unused_pass, length: {minimum: 5}, if: :url_auth_and_pass_present?
|
|
validates :mount_add, presence: true, if: :url_auth?
|
|
validates :mount_remove, presence: true, if: :url_auth?
|
|
validates :listener_add, presence: true, if: :url_auth?
|
|
validates :listener_remove, presence: true, if: :url_auth?
|
|
validates :auth_header, presence: true, if: :url_auth?
|
|
validates :timelimit_header, presence: true, if: :url_auth?
|
|
|
|
after_save :poke_config
|
|
|
|
def poke_config
|
|
IcecastServer.update(mount.servers, config_changed: 1) if mount
|
|
end
|
|
|
|
def to_s
|
|
"mount=#{mount} username=#{unused_username} auth_header=#{auth_header} timelimit_header=#{timelimit_header}"
|
|
end
|
|
|
|
def dumpXml (builder)
|
|
builder.tag! 'authentication', type: authentication_type do |auth|
|
|
auth.tag! 'option', name: 'mount_add', value: mount_add if !mount_add.nil? && !mount_remove.empty?
|
|
auth.tag! 'option', name: 'mount_remove', value: mount_remove if !mount_remove.nil? && !mount_remove.empty?
|
|
auth.tag! 'option', name: 'username', value: unused_username if !unused_username.nil? && !unused_username.empty?
|
|
auth.tag! 'option', name: 'password', value: unused_pass if !unused_pass.nil? && !unused_pass.empty?
|
|
auth.tag! 'option', name: 'listener_add', value: listener_add if !listener_add.nil? && !listener_add.empty?
|
|
auth.tag! 'option', name: 'listener_remove', value: listener_remove if !listener_remove.nil? && !listener_remove.empty?
|
|
auth.tag! 'option', name: 'auth_header', value: auth_header if !auth_header.nil? && !auth_header.empty?
|
|
auth.tag! 'option', name: 'timelimit_header', value: timelimit_header if !timelimit_header.nil? && !timelimit_header.empty?
|
|
end
|
|
end
|
|
|
|
def htpasswd_auth?
|
|
authentication_type == 'htpasswd'
|
|
end
|
|
|
|
def url_auth?
|
|
authentication_type == 'url'
|
|
end
|
|
|
|
def url_auth_and_user_present?
|
|
url_auth? && self.unused_username.present?
|
|
end
|
|
|
|
def url_auth_and_pass_present?
|
|
url_auth? && self.unused_pass.present?
|
|
end
|
|
|
|
end
|
|
end |