ok fix the API more

This commit is contained in:
Seth Call 2026-02-16 09:05:12 -06:00
parent 8f0b8929ba
commit 8613a03d00
2 changed files with 64 additions and 62 deletions

View File

@ -8,7 +8,7 @@ class ArsesController < ApplicationController
return return
end end
@arses = Ars.all @arses = JamRuby::Ars.all
render :json => @arses render :json => @arses
end end
@ -18,7 +18,14 @@ class ArsesController < ApplicationController
return return
end end
@ars = Ars.find_by_id(params[:id]) begin
# Primary ID lookup
@ars = JamRuby::Ars.find_by_id(params[:id])
# Explicit secondary lookups if primary ID fails
@ars ||= JamRuby::Ars.find_by_id_int(params[:id_int]) if params[:id_int]
@ars ||= JamRuby::Ars.find_by_name(params[:name]) if params[:name]
if @ars.nil? if @ars.nil?
render :json => {error: "Not Found"}, :status => 404 render :json => {error: "Not Found"}, :status => 404
return return
@ -36,10 +43,14 @@ class ArsesController < ApplicationController
else else
render :json => @ars.errors, :status => :unprocessable_entity render :json => @ars.errors, :status => :unprocessable_entity
end end
rescue => e
render :json => {error: e.message, backtrace: e.backtrace.first(5)}, :status => 500
end
end end
# create or update a client_artifact row # create or update a client_artifact row
def get_or_create def get_or_create
begin
name = params[:name] name = params[:name]
provider = params[:provider] provider = params[:provider]
active = params[:active] active = params[:active]
@ -48,17 +59,18 @@ class ArsesController < ApplicationController
password = params[:password] password = params[:password]
topology = params[:topology] topology = params[:topology]
ars_id = params[:ars_id] ars_id = params[:ars_id]
puts "TOPOLOGY #{topology}"
if ars_id # Explicit field-based lookups
ars = Ars.find_by_id_int(ars_id) ars = nil
end ars = JamRuby::Ars.find_by_id_int(ars_id) if ars_id
ars ||= JamRuby::Ars.find_by_name(name) if name
if ars.nil? if ars.nil?
ars = Ars.new ars = JamRuby::Ars.new
ars.name = name ars.name = name
ars.id_int = ars_id if !ars_id.nil?
end end
ars.id_int = ars_id if !ars_id.nil?
ars.provider = provider ars.provider = provider
ars.active = active ars.active = active
ars.ip = ip ars.ip = ip
@ -72,21 +84,12 @@ class ArsesController < ApplicationController
ars.longitude = topology['longitude'] ars.longitude = topology['longitude']
ars.subdivision = topology['subdivision'] ars.subdivision = topology['subdivision']
end end
ars.save ars.save!
@ars = ars @ars = ars
unless @ars.errors.any?
if ars_id.nil?
ars.reload
ars_id = ars.id_int
end
@ars = Ars.find_by_id_int(ars_id)
render :json => {id_int: @ars.id_int, id: @ars.id, name: @ars.name, provider: @ars.provider, active: @ars.active, ip: @ars.ip}, :status => :ok render :json => {id_int: @ars.id_int, id: @ars.id, name: @ars.name, provider: @ars.provider, active: @ars.active, ip: @ars.ip}, :status => :ok
else rescue => e
response.status = :unprocessable_entity render :json => {error: e.message, backtrace: e.backtrace.first(5)}, :status => 500
respond_with @ars end
end
end end
end end

View File

@ -1,8 +1,7 @@
module JamRuby module JamRuby
class Ars < ActiveRecord::Base class Ars < ActiveRecord::Base
attr_accessible :active, :name, :id_int, :ip, as: :admin attr_accessible :password, :username, :active, :beta, :name, :provider, :id_int, :ip, :port, :continent, :country, :city, :subdivision, :latitude, :longitude, as: :admin
self.table_name = "arses" self.table_name = "arses"
@@log = Logging.logger[Ars] @@log = Logging.logger[Ars]