Andrew Kane 63cebd9333 Fixed style | před 9 roky | |
---|---|---|
app | před 9 roky | |
config | před 10 roky | |
lib | před 9 roky | |
.gitignore | před 10 roky | |
CHANGELOG.md | před 9 roky | |
Gemfile | před 9 roky | |
LICENSE.txt | před 10 roky | |
README.md | před 9 roky | |
Rakefile | před 9 roky | |
blazer.gemspec | před 9 roky |
Share data effortlessly with your team
Blazer eliminates the need for many admin pages
Play around with the demo - data from MovieLens
Works with PostgreSQL and MySQL
:tangerine: Battle-tested at Instacart
Add this line to your application’s Gemfile:
gem 'blazer'
Run:
rails g blazer:install
rake db:migrate
And mount the dashboard in your config/routes.rb
:
mount Blazer::Engine, at: "blazer"
For production, specify your database:
ENV["BLAZER_DATABASE_URL"] = "postgres://user:password@hostname:5432/database_name"
It is highly, highly recommended to use a read only user. Keep reading to see how to create one.
Create a user with read only permissions:
BEGIN;
CREATE ROLE blazer LOGIN PASSWORD 'secret123';
GRANT CONNECT ON DATABASE database_name TO blazer;
GRANT USAGE ON SCHEMA public TO blazer;
GRANT SELECT ON ALL TABLES IN SCHEMA public TO blazer;
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO blazer;
COMMIT;
It is highly, highly recommended to protect sensitive information with views. Documentation coming soon.
Create a user with read only permissions:
GRANT SELECT, SHOW VIEW ON database_name.* TO blazer@’127.0.0.1′ IDENTIFIED BY ‘secret123‘;
FLUSH PRIVILEGES;
It is highly, highly recommended to protect sensitive information with views. Documentation coming soon.
Don’t forget to protect the dashboard in production.
Set the following variables in your environment or an initializer.
ENV["BLAZER_USERNAME"] = "andrew"
ENV["BLAZER_PASSWORD"] = "secret"
authenticate :user, lambda{|user| user.admin? } do
mount Blazer::Engine, at: "blazer"
end
Change time zone
Blazer.time_zone = "Pacific Time (US & Canada)"
Change timeout PostgreSQL only
Blazer.timeout = 10 # defaults to 15
Turn off audits
Blazer.audit = false
Custom user class
Blazer.user_class = "Admin"
Customize user name
Blazer.user_name = :first_name
Blazer will automatically generate charts based on the types of the columns returned in your query
If there are at least 2 columns and the first is a timestamp and all other columns are numeric, a line chart will be generated
If there are 2 columns and the first column is a string and the second column is a numeric, a pie chart will be generated
View the changelog
Blazer uses a number of awesome, open source projects.
Everyone is encouraged to help improve this project. Here are a few ways you can help: