DV_RUBY_SDK 1.0.1 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +206 -18
  3. data/examples/rails/devless/.gitignore +21 -0
  4. data/examples/rails/devless/Gemfile +55 -0
  5. data/examples/rails/devless/Gemfile.lock +176 -0
  6. data/examples/rails/devless/README.md +73 -0
  7. data/examples/rails/devless/Rakefile +6 -0
  8. data/examples/rails/devless/app/assets/config/manifest.js +3 -0
  9. data/examples/rails/devless/app/assets/images/.keep +0 -0
  10. data/examples/rails/devless/app/assets/javascripts/application.js +16 -0
  11. data/examples/rails/devless/app/assets/javascripts/cable.js +13 -0
  12. data/examples/rails/devless/app/assets/javascripts/channels/.keep +0 -0
  13. data/examples/rails/devless/app/assets/javascripts/devless.coffee +3 -0
  14. data/examples/rails/devless/app/assets/stylesheets/application.css +15 -0
  15. data/examples/rails/devless/app/assets/stylesheets/devless.scss +3 -0
  16. data/examples/rails/devless/app/channels/application_cable/channel.rb +4 -0
  17. data/examples/rails/devless/app/channels/application_cable/connection.rb +4 -0
  18. data/examples/rails/devless/app/controllers/application_controller.rb +3 -0
  19. data/examples/rails/devless/app/controllers/concerns/.keep +0 -0
  20. data/examples/rails/devless/app/controllers/devless_controller.rb +19 -0
  21. data/examples/rails/devless/app/helpers/application_helper.rb +2 -0
  22. data/examples/rails/devless/app/helpers/devless_helper.rb +2 -0
  23. data/examples/rails/devless/app/jobs/application_job.rb +2 -0
  24. data/examples/rails/devless/app/mailers/application_mailer.rb +4 -0
  25. data/examples/rails/devless/app/models/application_record.rb +3 -0
  26. data/examples/rails/devless/app/models/concerns/.keep +0 -0
  27. data/examples/rails/devless/app/views/devless/index.html.erb +4 -0
  28. data/examples/rails/devless/app/views/layouts/application.html.erb +14 -0
  29. data/examples/rails/devless/app/views/layouts/mailer.html.erb +13 -0
  30. data/examples/rails/devless/app/views/layouts/mailer.text.erb +1 -0
  31. data/examples/rails/devless/bin/bundle +3 -0
  32. data/examples/rails/devless/bin/rails +9 -0
  33. data/examples/rails/devless/bin/rake +9 -0
  34. data/examples/rails/devless/bin/setup +34 -0
  35. data/examples/rails/devless/bin/spring +17 -0
  36. data/examples/rails/devless/bin/update +29 -0
  37. data/examples/rails/devless/config.ru +5 -0
  38. data/examples/rails/devless/config/application.rb +15 -0
  39. data/examples/rails/devless/config/boot.rb +3 -0
  40. data/examples/rails/devless/config/cable.yml +9 -0
  41. data/examples/rails/devless/config/database.yml +25 -0
  42. data/examples/rails/devless/config/environment.rb +5 -0
  43. data/examples/rails/devless/config/environments/development.rb +54 -0
  44. data/examples/rails/devless/config/environments/production.rb +86 -0
  45. data/examples/rails/devless/config/environments/test.rb +42 -0
  46. data/examples/rails/devless/config/initializers/application_controller_renderer.rb +6 -0
  47. data/examples/rails/devless/config/initializers/assets.rb +11 -0
  48. data/examples/rails/devless/config/initializers/backtrace_silencers.rb +7 -0
  49. data/examples/rails/devless/config/initializers/cookies_serializer.rb +5 -0
  50. data/examples/rails/devless/config/initializers/devless.rb +2 -0
  51. data/examples/rails/devless/config/initializers/filter_parameter_logging.rb +4 -0
  52. data/examples/rails/devless/config/initializers/inflections.rb +16 -0
  53. data/examples/rails/devless/config/initializers/mime_types.rb +4 -0
  54. data/examples/rails/devless/config/initializers/new_framework_defaults.rb +24 -0
  55. data/examples/rails/devless/config/initializers/session_store.rb +3 -0
  56. data/examples/rails/devless/config/initializers/wrap_parameters.rb +14 -0
  57. data/examples/rails/devless/config/locales/en.yml +23 -0
  58. data/examples/rails/devless/config/puma.rb +47 -0
  59. data/examples/rails/devless/config/routes.rb +5 -0
  60. data/examples/rails/devless/config/secrets.yml +22 -0
  61. data/examples/rails/devless/config/spring.rb +6 -0
  62. data/examples/rails/devless/db/seeds.rb +7 -0
  63. data/examples/rails/devless/lib/assets/.keep +0 -0
  64. data/examples/rails/devless/lib/tasks/.keep +0 -0
  65. data/examples/rails/devless/log/.keep +0 -0
  66. data/examples/rails/devless/public/404.html +67 -0
  67. data/examples/rails/devless/public/422.html +67 -0
  68. data/examples/rails/devless/public/500.html +66 -0
  69. data/examples/rails/devless/public/apple-touch-icon-precomposed.png +0 -0
  70. data/examples/rails/devless/public/apple-touch-icon.png +0 -0
  71. data/examples/rails/devless/public/favicon.ico +0 -0
  72. data/examples/rails/devless/public/robots.txt +5 -0
  73. data/examples/rails/devless/test/controllers/.keep +0 -0
  74. data/examples/rails/devless/test/controllers/devless_controller_test.rb +9 -0
  75. data/examples/rails/devless/test/fixtures/.keep +0 -0
  76. data/examples/rails/devless/test/fixtures/files/.keep +0 -0
  77. data/examples/rails/devless/test/helpers/.keep +0 -0
  78. data/examples/rails/devless/test/integration/.keep +0 -0
  79. data/examples/rails/devless/test/mailers/.keep +0 -0
  80. data/examples/rails/devless/test/models/.keep +0 -0
  81. data/examples/rails/devless/test/test_helper.rb +10 -0
  82. data/examples/rails/devless/tmp/.keep +0 -0
  83. data/examples/rails/devless/vendor/assets/javascripts/.keep +0 -0
  84. data/examples/rails/devless/vendor/assets/stylesheets/.keep +0 -0
  85. data/examples/ruby_script/devless.rb +65 -0
  86. data/lib/DV_RUBY_SDK.rb +5 -2
  87. data/lib/DV_RUBY_SDK/version.rb +1 -1
  88. metadata +93 -10
@@ -0,0 +1,73 @@
1
+ # DEVLESS RAILS EXAMPLE (THE WHOLE PROCESS)
2
+
3
+ ## Step One
4
+ Create a rails app from your terminal and name it anything I will call mine "devless"
5
+ ```
6
+ $ rails new devless
7
+ ```
8
+ Navigate into the folder from terminal and run bundle
9
+ ```
10
+ $ bundle
11
+ ```
12
+
13
+ ## Step Two
14
+ Add The 'DV_RUBY_SDK' gem by going into your gem file and pasting this code
15
+ ```Ruby
16
+ gem 'DV_RUBY_SDK'
17
+ ```
18
+
19
+ Go back to your console and run bundle install
20
+ ```
21
+ $ bundle install
22
+ ```
23
+
24
+ Create a controller with an action in my case I will create a controller called devless with an index action. This is how I will do it.
25
+
26
+ ```
27
+ $ rails g controller devless index
28
+ ```
29
+
30
+ ## Step Three
31
+ #### Navigate to your config folder in the root and look for a folder called initializers. Create a file called devless.rb to configure devless. This the src config/initializers/devless.rb. You will need a token and a url to configure
32
+
33
+ ##### You will see your {token} and the app {url} in the app section of the devless app you created on hosted on heroku. Click on the app tab and on your left and just scroll down on your right you will see the token copy it.
34
+ ##### Url: Just copy the root of the devless app you created and hosted on heroku
35
+
36
+ In my case my token is "7740b4b2303e32957a3215c344b8c21c" and my url is "http://newerapper.herokuapp.com" so since i have these can configure.
37
+
38
+
39
+ #### Go to config/initializers/devless.rb and paste this code (Use your token and url not this)
40
+ ```Ruby
41
+ DVRUBYSDK.token = "7740b4b2303e32957a3215c344b8c21c"
42
+ DVRUBYSDK.url = "http://newerapper.herokuapp.com"
43
+ ```
44
+
45
+ ## Step Four
46
+ Navigate to app/controller and let's write some logic in the controller we created so we can post and query data on our devless backend. Copy and paste this code in the index action of your controller or you can also paste it in any action in your controller. Please read the comments to see what you have to do to customize it well.
47
+
48
+ ```Ruby
49
+ #create an instance of the devless class and assign it to a varibale.
50
+ # I will call mine *@devless* but you could call yours anything.
51
+
52
+ @devless = DVRUBYSDK::Devless.new
53
+
54
+ #At this stage we can query data, post data, patch and do what ever we want to our table from here
55
+ #Lets first query data
56
+ service_name = "names"
57
+ table_name = "eit_names"
58
+ @query_response = @devless.query_data(service_name, table_name)
59
+
60
+ #lets post data to that same table called "eit_names" which require one field ie "name"
61
+ @data_we_want_to_post = {name: "Charles"}
62
+ @post_data_response = devless.add_data(service_name, table_name, data_we_want_to_post)
63
+ ```
64
+ ## Step Five
65
+ Access your data from the view or wherever you want to use it. So lets go to our view for the controller ie views/devless/index.html.erb in our case and paste this code and that is it!! Easy!
66
+ ```Rails
67
+ <%= @query_response %>
68
+ <%= @post_data_response %>
69
+ ```
70
+
71
+ This is It you can do whatever you want with it read more methods in the sdk documentation. It is super easy, fast and efficient. Tell your friends about devless.
72
+
73
+ If you already have this just download this project and run bundle install on your local change the config/initializers/devless.rb and start using it. happy coding!!. Welcome to Devless
@@ -0,0 +1,6 @@
1
+ # Add your own tasks in files placed in lib/tasks ending in .rake,
2
+ # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
3
+
4
+ require_relative 'config/application'
5
+
6
+ Rails.application.load_tasks
@@ -0,0 +1,3 @@
1
+ //= link_tree ../images
2
+ //= link_directory ../javascripts .js
3
+ //= link_directory ../stylesheets .css
File without changes
@@ -0,0 +1,16 @@
1
+ // This is a manifest file that'll be compiled into application.js, which will include all the files
2
+ // listed below.
3
+ //
4
+ // Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
5
+ // or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path.
6
+ //
7
+ // It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
8
+ // compiled file. JavaScript code in this file should be added after the last require_* statement.
9
+ //
10
+ // Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
11
+ // about supported directives.
12
+ //
13
+ //= require jquery
14
+ //= require jquery_ujs
15
+ //= require turbolinks
16
+ //= require_tree .
@@ -0,0 +1,13 @@
1
+ // Action Cable provides the framework to deal with WebSockets in Rails.
2
+ // You can generate new channels where WebSocket features live using the rails generate channel command.
3
+ //
4
+ //= require action_cable
5
+ //= require_self
6
+ //= require_tree ./channels
7
+
8
+ (function() {
9
+ this.App || (this.App = {});
10
+
11
+ App.cable = ActionCable.createConsumer();
12
+
13
+ }).call(this);
@@ -0,0 +1,3 @@
1
+ # Place all the behaviors and hooks related to the matching controller here.
2
+ # All this logic will automatically be available in application.js.
3
+ # You can use CoffeeScript in this file: http://coffeescript.org/
@@ -0,0 +1,15 @@
1
+ /*
2
+ * This is a manifest file that'll be compiled into application.css, which will include all the files
3
+ * listed below.
4
+ *
5
+ * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
6
+ * or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
7
+ *
8
+ * You're free to add application-wide styles to this file and they'll appear at the bottom of the
9
+ * compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS
10
+ * files in this directory. Styles in this file should be added after the last require_* statement.
11
+ * It is generally better to create a new file per style scope.
12
+ *
13
+ *= require_tree .
14
+ *= require_self
15
+ */
@@ -0,0 +1,3 @@
1
+ // Place all the styles related to the devless controller here.
2
+ // They will automatically be included in application.css.
3
+ // You can use Sass (SCSS) here: http://sass-lang.com/
@@ -0,0 +1,4 @@
1
+ module ApplicationCable
2
+ class Channel < ActionCable::Channel::Base
3
+ end
4
+ end
@@ -0,0 +1,4 @@
1
+ module ApplicationCable
2
+ class Connection < ActionCable::Connection::Base
3
+ end
4
+ end
@@ -0,0 +1,3 @@
1
+ class ApplicationController < ActionController::Base
2
+ protect_from_forgery with: :exception
3
+ end
@@ -0,0 +1,19 @@
1
+ class DevlessController < ApplicationController
2
+ def index
3
+ #create an intance of the devless class and assign it to a varibale.
4
+ # I will call mine *@devless* you could call yours anything.
5
+
6
+ @devless = DVRUBYSDK::Devless.new
7
+
8
+ #at this stage we can query data, post data, patch and do what ever we want to our table from here
9
+ #lets first query data
10
+ service_name = "names"
11
+ table_name = "eit_names"
12
+ @query_response = @devless.query_data(service_name, table_name)
13
+
14
+ #lets post data to that same table called "eit_names" which require one field ie "name"
15
+ @data_we_want_to_post = {name: "Charles"}
16
+ @post_data_response = devless.add_data(service_name, table_name, data_we_want_to_post)
17
+
18
+ end
19
+ end
@@ -0,0 +1,2 @@
1
+ module ApplicationHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ module DevlessHelper
2
+ end
@@ -0,0 +1,2 @@
1
+ class ApplicationJob < ActiveJob::Base
2
+ end
@@ -0,0 +1,4 @@
1
+ class ApplicationMailer < ActionMailer::Base
2
+ default from: 'from@example.com'
3
+ layout 'mailer'
4
+ end
@@ -0,0 +1,3 @@
1
+ class ApplicationRecord < ActiveRecord::Base
2
+ self.abstract_class = true
3
+ end
File without changes
@@ -0,0 +1,4 @@
1
+ <h1>Devless#index</h1>
2
+ <p>Welcome to the devless Index page</p>
3
+ <%= "Query Response: #{@query_response}" %>
4
+ <%= "Post Response: #{@post_data_response}"
@@ -0,0 +1,14 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Devless</title>
5
+ <%= csrf_meta_tags %>
6
+
7
+ <%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>
8
+ <%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload' %>
9
+ </head>
10
+
11
+ <body>
12
+ <%= yield %>
13
+ </body>
14
+ </html>
@@ -0,0 +1,13 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5
+ <style>
6
+ /* Email styles need to be inline */
7
+ </style>
8
+ </head>
9
+
10
+ <body>
11
+ <%= yield %>
12
+ </body>
13
+ </html>
@@ -0,0 +1 @@
1
+ <%= yield %>
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env ruby
2
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
3
+ load Gem.bin_path('bundler', 'bundle')
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env ruby
2
+ begin
3
+ load File.expand_path('../spring', __FILE__)
4
+ rescue LoadError => e
5
+ raise unless e.message.include?('spring')
6
+ end
7
+ APP_PATH = File.expand_path('../config/application', __dir__)
8
+ require_relative '../config/boot'
9
+ require 'rails/commands'
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env ruby
2
+ begin
3
+ load File.expand_path('../spring', __FILE__)
4
+ rescue LoadError => e
5
+ raise unless e.message.include?('spring')
6
+ end
7
+ require_relative '../config/boot'
8
+ require 'rake'
9
+ Rake.application.run
@@ -0,0 +1,34 @@
1
+ #!/usr/bin/env ruby
2
+ require 'pathname'
3
+ require 'fileutils'
4
+ include FileUtils
5
+
6
+ # path to your application root.
7
+ APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
8
+
9
+ def system!(*args)
10
+ system(*args) || abort("\n== Command #{args} failed ==")
11
+ end
12
+
13
+ chdir APP_ROOT do
14
+ # This script is a starting point to setup your application.
15
+ # Add necessary setup steps to this file.
16
+
17
+ puts '== Installing dependencies =='
18
+ system! 'gem install bundler --conservative'
19
+ system('bundle check') || system!('bundle install')
20
+
21
+ # puts "\n== Copying sample files =="
22
+ # unless File.exist?('config/database.yml')
23
+ # cp 'config/database.yml.sample', 'config/database.yml'
24
+ # end
25
+
26
+ puts "\n== Preparing database =="
27
+ system! 'bin/rails db:setup'
28
+
29
+ puts "\n== Removing old logs and tempfiles =="
30
+ system! 'bin/rails log:clear tmp:clear'
31
+
32
+ puts "\n== Restarting application server =="
33
+ system! 'bin/rails restart'
34
+ end
@@ -0,0 +1,17 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ # This file loads spring without using Bundler, in order to be fast.
4
+ # It gets overwritten when you run the `spring binstub` command.
5
+
6
+ unless defined?(Spring)
7
+ require 'rubygems'
8
+ require 'bundler'
9
+
10
+ lockfile = Bundler::LockfileParser.new(Bundler.default_lockfile.read)
11
+ spring = lockfile.specs.detect { |spec| spec.name == "spring" }
12
+ if spring
13
+ Gem.use_paths Gem.dir, Bundler.bundle_path.to_s, *Gem.path
14
+ gem 'spring', spring.version
15
+ require 'spring/binstub'
16
+ end
17
+ end
@@ -0,0 +1,29 @@
1
+ #!/usr/bin/env ruby
2
+ require 'pathname'
3
+ require 'fileutils'
4
+ include FileUtils
5
+
6
+ # path to your application root.
7
+ APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
8
+
9
+ def system!(*args)
10
+ system(*args) || abort("\n== Command #{args} failed ==")
11
+ end
12
+
13
+ chdir APP_ROOT do
14
+ # This script is a way to update your development environment automatically.
15
+ # Add necessary update steps to this file.
16
+
17
+ puts '== Installing dependencies =='
18
+ system! 'gem install bundler --conservative'
19
+ system('bundle check') || system!('bundle install')
20
+
21
+ puts "\n== Updating database =="
22
+ system! 'bin/rails db:migrate'
23
+
24
+ puts "\n== Removing old logs and tempfiles =="
25
+ system! 'bin/rails log:clear tmp:clear'
26
+
27
+ puts "\n== Restarting application server =="
28
+ system! 'bin/rails restart'
29
+ end
@@ -0,0 +1,5 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require_relative 'config/environment'
4
+
5
+ run Rails.application
@@ -0,0 +1,15 @@
1
+ require_relative 'boot'
2
+
3
+ require 'rails/all'
4
+
5
+ # Require the gems listed in Gemfile, including any gems
6
+ # you've limited to :test, :development, or :production.
7
+ Bundler.require(*Rails.groups)
8
+
9
+ module Devless
10
+ class Application < Rails::Application
11
+ # Settings in config/environments/* take precedence over those specified here.
12
+ # Application configuration should go into files in config/initializers
13
+ # -- all .rb files in that directory are automatically loaded.
14
+ end
15
+ end
@@ -0,0 +1,3 @@
1
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../Gemfile', __dir__)
2
+
3
+ require 'bundler/setup' # Set up gems listed in the Gemfile.
@@ -0,0 +1,9 @@
1
+ development:
2
+ adapter: async
3
+
4
+ test:
5
+ adapter: async
6
+
7
+ production:
8
+ adapter: redis
9
+ url: redis://localhost:6379/1
@@ -0,0 +1,25 @@
1
+ # SQLite version 3.x
2
+ # gem install sqlite3
3
+ #
4
+ # Ensure the SQLite 3 gem is defined in your Gemfile
5
+ # gem 'sqlite3'
6
+ #
7
+ default: &default
8
+ adapter: sqlite3
9
+ pool: 5
10
+ timeout: 5000
11
+
12
+ development:
13
+ <<: *default
14
+ database: db/development.sqlite3
15
+
16
+ # Warning: The database defined as "test" will be erased and
17
+ # re-generated from your development database when you run "rake".
18
+ # Do not set this db to the same as development or production.
19
+ test:
20
+ <<: *default
21
+ database: db/test.sqlite3
22
+
23
+ production:
24
+ <<: *default
25
+ database: db/production.sqlite3
@@ -0,0 +1,5 @@
1
+ # Load the Rails application.
2
+ require_relative 'application'
3
+
4
+ # Initialize the Rails application.
5
+ Rails.application.initialize!