Sette opp Geocoder med Sinatra og Active?

stemmer
1

Jeg har en MYSQL database som er tilgjengelig ved hjelp av Active og Sinatra. Jeg prøver å utføre visse geolocation oppgave på postene i tabellene.

Men jeg tror min syntaks er galt som å utvide geocoder klassen gjør min CRUD forespørsel mislykkes:

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

Spørringen jeg prøver å gjøre er: Post.near([@lat, @long], @dist, units: :km).offset(10 * @var.to_i).first(10)

Dette Stackoverflow tråden her tyder også på at jeg trenger å sette opp flere argumenter som attr_accessors. Hvordan går jeg om å sette opp omskriving over så jeg kan bruke Geocoder sin nearmetode?

Publisert på 25/07/2018 klokken 13:24
kilden bruker
På andre språk...                            


1 svar

stemmer
1

Jeg fast ovenfor ved å tilsette:

require 'geocoder'

og

reverse_geocoded_by :latitude, :longitude
Svarte 25/07/2018 kl. 18:32
kilden bruker

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