Impostazione Geocoder con Sinatra e ActiveRecord?

voti
1

Ho un database MYSQL a cui si accede utilizzando ActiveRecord e Sinatra. Sto cercando di eseguire alcuni compiti di geolocalizzazione sui record nelle tabelle.

Tuttavia, credo che la mia sintassi è sbagliato, come l'estensione della classe geocoder rende la mia richiesta CRUD venga meno;

myapp.rb

require 'rubygems'
require 'sinatra'
require 'active_record'
require 'table_print'
require 'json'

ActiveRecord::Base.establish_connection(
  :adapter  => mysql2,
  :host     => localhost,
  :username => root,
  :database => orbital
)

class Post < ActiveRecord::Base
  extend Geocoder::Model::ActiveRecord

 # attr_accessor :latitude, :longitude
end

class Comment < ActiveRecord::Base
  #extend Geocoder::Model::ActiveRecord
end

class MyApp < Sinatra::Application
  #extend Geocoder::Model::ActiveRecord
end

post '/post' do
  @user = params[:user]
  @content = params[:content]
  @latitude = params[:latitude]
  @longitude = params[:longitude]
  @timestamp = params[:timestamp]
  record = Post.create(user: @user, content: @content, longitude: @longitude, latitude: @latitude, timestamp: @timestamp)
  record.save
end

La query che sto cercando di realizzare è: Post.near([@lat, @long], @dist, units: :km).offset(10 * @var.to_i).first(10)

Questo thread StackOverflow qui suggerisce anche che devo installare argomenti aggiuntivi come attr_accessors. Come posso fare per impostare riscrivere il sopra così posso usare di Geocoder nearmetodo?

È pubblicato 25/07/2018 alle 13:24
fonte dall'utente
In altre lingue...                            


1 risposte

voti
1

Ho sistemato il precedente aggiungendo:

require 'geocoder'

e

reverse_geocoded_by :latitude, :longitude
Risposto il 25/07/2018 a 18:32
fonte dall'utente

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more