thecore_mssql_importer_common 0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 69abcb43788707b76c4183bdba70819f732342d83a324d88a554c023c8458b36
4
+ data.tar.gz: e20b5af3387a50646979fc9a892155c71c30a502d815d1516c8045af905ebff6
5
+ SHA512:
6
+ metadata.gz: 8a5f459e76775a647cccf3c25b7f9b3ad7b849ca14cb971d187b1d4e854b26f0ff4e656571ec0ca4661a26dd0ed54c2132792746524ac0938458d98ebd1f99a8
7
+ data.tar.gz: c48e282a0f0c944ee3a30f2d64e34ec770f919b4785f5bc9340ffe3ff7537fb0fea02194bbb1889e69bdcab5312a8af035425a5d56d97174baed8f2dd464d317
@@ -0,0 +1,20 @@
1
+ Copyright 2018 Gabriele Tassoni
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,28 @@
1
+ # ThecoreMssqlImporterCommon
2
+ Short description and motivation.
3
+
4
+ ## Usage
5
+ How to use my plugin.
6
+
7
+ ## Installation
8
+ Add this line to your application's Gemfile:
9
+
10
+ ```ruby
11
+ gem 'thecore_mssql_importer_common'
12
+ ```
13
+
14
+ And then execute:
15
+ ```bash
16
+ $ bundle
17
+ ```
18
+
19
+ Or install it yourself as:
20
+ ```bash
21
+ $ gem install thecore_mssql_importer_common
22
+ ```
23
+
24
+ ## Contributing
25
+ Contribution directions go here.
26
+
27
+ ## License
28
+ The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
@@ -0,0 +1,32 @@
1
+ begin
2
+ require 'bundler/setup'
3
+ rescue LoadError
4
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
5
+ end
6
+
7
+ require 'rdoc/task'
8
+
9
+ RDoc::Task.new(:rdoc) do |rdoc|
10
+ rdoc.rdoc_dir = 'rdoc'
11
+ rdoc.title = 'ThecoreMssqlImporterCommon'
12
+ rdoc.options << '--line-numbers'
13
+ rdoc.rdoc_files.include('README.md')
14
+ rdoc.rdoc_files.include('lib/**/*.rb')
15
+ end
16
+
17
+ APP_RAKEFILE = File.expand_path("test/dummy/Rakefile", __dir__)
18
+ load 'rails/tasks/engine.rake'
19
+
20
+ load 'rails/tasks/statistics.rake'
21
+
22
+ require 'bundler/gem_tasks'
23
+
24
+ require 'rake/testtask'
25
+
26
+ Rake::TestTask.new(:test) do |t|
27
+ t.libs << 'test'
28
+ t.pattern = 'test/**/*_test.rb'
29
+ t.verbose = false
30
+ end
31
+
32
+ task default: :test
@@ -0,0 +1,23 @@
1
+
2
+ require 'active_support/concern'
3
+
4
+ module ThecoreMssqlImporterCommonAbilitiesConcern
5
+ extend ActiveSupport::Concern
6
+ included do
7
+ def thecore_mssql_importer_common_abilities user
8
+ if user
9
+ # if the user is logged in, it can do certain tasks regardless his role
10
+ if user.admin?
11
+ # if the user is an admin, it can do a lot of things, usually
12
+ end
13
+
14
+ if user.has_role? :role
15
+ # a specific role, brings specific powers
16
+ end
17
+ end
18
+ end
19
+ end
20
+ end
21
+
22
+ # include the extension
23
+ TheCoreAbilities.send(:include, ThecoreMssqlImporterCommonAbilitiesConcern)
@@ -0,0 +1,5 @@
1
+
2
+ Rails.application.configure do
3
+ config.after_initialize do
4
+ end
5
+ end
@@ -0,0 +1,2 @@
1
+ Rails.application.routes.draw do
2
+ end
@@ -0,0 +1,11 @@
1
+ class AddSqlServerConnectorParams < ActiveRecord::Migration[5.2]
2
+ def change
3
+ Settings.ns('mssql_connector').username = 'sa'
4
+ Settings.ns('mssql_connector').password = 'your_password'
5
+ Settings.ns('mssql_connector').host = 'localhost'
6
+ Settings.ns('mssql_connector').port = 1433
7
+ Settings.ns('mssql_connector').database = 'test'
8
+ Settings.ns('mssql_connector').table_read = 'test_table'
9
+ Settings.ns('mssql_connector').latest_migration_code = ''
10
+ end
11
+ end
@@ -0,0 +1,34 @@
1
+ require 'tiny_tds'
2
+
3
+ class MSSQLImporterCommon
4
+ # "Just tests connection to the DB configured in Settings."
5
+ def self.ping_mssql_server
6
+ connect
7
+ puts 'Connecting to SQL Server'
8
+
9
+ if @client.active? == true then puts 'Done' end
10
+
11
+ @client.close
12
+ end
13
+
14
+ # "Retrieves all records from the reading table."
15
+ def self.get_all_records
16
+ connect
17
+ # Read all employees
18
+ puts "Reading data from table"
19
+ @client.execute("SELECT * FROM #{Settings.ns('mssql_connector').table_read}").each do |row|
20
+ puts row
21
+ end
22
+ end
23
+
24
+ def self.connect
25
+ conn = {
26
+ username: Settings.ns('mssql_connector').username,
27
+ password: Settings.ns('mssql_connector').password,
28
+ host: Settings.ns('mssql_connector').host,
29
+ port: Settings.ns('mssql_connector').port,
30
+ database: Settings.ns('mssql_connector').database,
31
+ }
32
+ @client = TinyTds::Client.new conn
33
+ end
34
+ end
@@ -0,0 +1,13 @@
1
+ require 'tracker_importer'
2
+
3
+ namespace :mssql_importer_common do
4
+ desc "Just tests connection to the DB configured in Settings."
5
+ task ping_mssql_server: :environment do
6
+ MSSQLImporterCommon.ping_mssql_server
7
+ end
8
+
9
+ desc "Retrieves all records from the reading table."
10
+ task get_all_records: :environment do
11
+ MSSQLImporterCommon.get_all_records
12
+ end
13
+ end
@@ -0,0 +1,8 @@
1
+
2
+ require 'thecore'
3
+ require "thecore_mssql_importer_common/engine"
4
+ require 'mssql_importer_common'
5
+
6
+ module ThecoreMssqlImporterCommon
7
+ # Your code goes here...
8
+ end
@@ -0,0 +1,15 @@
1
+ require 'thecore'
2
+ module ThecoreMssqlImporterCommon
3
+ class Engine < ::Rails::Engine
4
+
5
+ initializer 'thecore_mssql_importer_common.add_to_migrations' do |app|
6
+ unless app.root.to_s.match root.to_s
7
+ # APPEND TO MAIN APP MIGRATIONS FROM THIS GEM
8
+ config.paths['db/migrate'].expanded.each do |expanded_path|
9
+ app.config.paths['db/migrate'] << expanded_path
10
+ end
11
+ end
12
+ end
13
+
14
+ end
15
+ end
@@ -0,0 +1,3 @@
1
+ module ThecoreMssqlImporterCommon
2
+ VERSION = "#{`git describe --tags $(git rev-list --tags --max-count=1)`}"
3
+ end
metadata ADDED
@@ -0,0 +1,95 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: thecore_mssql_importer_common
3
+ version: !ruby/object:Gem::Version
4
+ version: '0'
5
+ platform: ruby
6
+ authors:
7
+ - Gabriele Tassoni
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2020-11-03 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: thecore
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: tiny_tds
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '2.1'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '2.1'
41
+ description: Thecorized thecore_mssql_importer_common full description.
42
+ email:
43
+ - gabriele.tassoni@gmail.com
44
+ executables: []
45
+ extensions: []
46
+ extra_rdoc_files: []
47
+ files:
48
+ - MIT-LICENSE
49
+ - README.md
50
+ - Rakefile
51
+ - app/assets/config/thecore_mssql_importer_common_manifest.js
52
+ - config/initializers/abilities_thecore_mssql_importer_common_concern.rb
53
+ - config/initializers/thecore_mssql_importer_common_after_initialize.rb
54
+ - config/routes.rb
55
+ - db/migrate/20180621103713_add_sql_server_connector_params.rb
56
+ - lib/mssql_importer_common.rb
57
+ - lib/tasks/thecore_mssql_importer_common_tasks.rake
58
+ - lib/thecore_mssql_importer_common.rb
59
+ - lib/thecore_mssql_importer_common/engine.rb
60
+ - lib/thecore_mssql_importer_common/version.rb
61
+ homepage: https://www.taris.it
62
+ licenses:
63
+ - MIT
64
+ metadata: {}
65
+ post_install_message: |2+
66
+
67
+ Please remember to change the following params either using a migration or by editing via the GUI:
68
+
69
+ Settings.ns('mssql_connector').username = 'sa'
70
+ Settings.ns('mssql_connector').password = 'your_password'
71
+ Settings.ns('mssql_connector').host = 'localhost'
72
+ Settings.ns('mssql_connector').port = 1433
73
+ Settings.ns('mssql_connector').database = 'test'
74
+ Settings.ns('mssql_connector').table_read = 'test_table'
75
+ Settings.ns('mssql_connector').latest_migration_code = ''
76
+
77
+ rdoc_options: []
78
+ require_paths:
79
+ - lib
80
+ required_ruby_version: !ruby/object:Gem::Requirement
81
+ requirements:
82
+ - - ">="
83
+ - !ruby/object:Gem::Version
84
+ version: '0'
85
+ required_rubygems_version: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ requirements: []
91
+ rubygems_version: 3.0.3
92
+ signing_key:
93
+ specification_version: 4
94
+ summary: Thecorized thecore_mssql_importer_common
95
+ test_files: []