#encoding: utf-8 require 'fileutils' require 'active_record' module Recorder module DB def self.prepare database_path = File.join(ENV['HOME'], '.recorder','recorder.sqlite3') connect_database database_path create_table_if_not_exists database_path end def self.connect_database(path) spec = {adapter: 'sqlite3', database: path} ActiveRecord::Base.establish_connection spec end def self.create_table_if_not_exists(path) create_database_path path connection = ActiveRecord::Base.connection return if connection.table_exists?(:data) connection.create_table :data do |d| d.column :weight, :real, null: false d.column :bodyfat, :real, null: true d.column :date, :text, null: true d.timestamps end connection.add_index :data, :created_at connection.add_index :data, :date end def self.create_database_path(path) FileUtils.mkdir_p File.dirname(path) end private_class_method :connect_database, :create_table_if_not_exists, :create_database_path end end