ragic_client 0.1.3

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 95cef99984d3af55b1dd0cd49407c5220fdc0c775a843517624381dd87526c6c
4
+ data.tar.gz: e4bf487182f310b08ded26e3545ba015becbea09bfbe20c06bf983573d7ef153
5
+ SHA512:
6
+ metadata.gz: ecabeae056f53d1b442d5658d607b7f442be551eb0fdde7343c39a97e23e6797925c1e302fc0f872fb114ba4cb35298a9a182eafe4286e42f1fae8d7a95ca161
7
+ data.tar.gz: d7d10fd25c9b956fb1493fa530d226088a057a17ed2c12228cc78a40d804db826b810e6c6fe51c75015cdbd8c6d5a7ed7f50c0856f0cc7ad74fe3d6b05543c19
@@ -0,0 +1,8 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /_yardoc/
4
+ /coverage/
5
+ /doc/
6
+ /pkg/
7
+ /spec/reports/
8
+ /tmp/
File without changes
data/Gemfile ADDED
@@ -0,0 +1,7 @@
1
+ source "https://rubygems.org"
2
+
3
+ # Specify your gem's dependencies in ragic_client.gemspec
4
+ gemspec
5
+
6
+ gem "rake", "~> 12.0"
7
+ gem "httparty"
@@ -0,0 +1,23 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ ragic_client (0.1.3)
5
+
6
+ GEM
7
+ remote: https://rubygems.org/
8
+ specs:
9
+ httparty (0.16.2)
10
+ multi_xml (>= 0.5.2)
11
+ multi_xml (0.6.0)
12
+ rake (12.3.3)
13
+
14
+ PLATFORMS
15
+ ruby
16
+
17
+ DEPENDENCIES
18
+ httparty
19
+ ragic_client!
20
+ rake (~> 12.0)
21
+
22
+ BUNDLED WITH
23
+ 2.1.4
@@ -0,0 +1,102 @@
1
+ # RagicClient
2
+
3
+ RagicClient is a simple tool integrate with [Ragic System](https://ragic.com). It's free and quite easy to use :smile: .
4
+
5
+ [Ragic HTTP API Integration Guide](https://www.ragic.com/intl/en/doc-api).
6
+
7
+ # Features
8
+
9
+ - **[Create Entry](#create-entry)**
10
+ - **[Update Entry](#update-entry)**
11
+ - **[Delete Entry](#delete-entry)**
12
+ - **[Find Entry By ID](#find-entry-by-id)**
13
+ - **[Find Entry By Field ID And Value](#find-entry-by-field-id-and-value)**
14
+
15
+ ## Installation
16
+
17
+ Add this line to your application's Gemfile:
18
+
19
+ ```ruby
20
+ gem 'ragic_client'
21
+ ```
22
+
23
+ And then execute:
24
+
25
+ $ bundle
26
+
27
+ Or install it yourself as:
28
+
29
+ $ gem install ragic_client
30
+
31
+ ## Usage
32
+
33
+ ### Config
34
+
35
+ First thing you need to set up is placing something like this either in initializer or in application.rb file:
36
+
37
+ ```ruby
38
+ RagicClient.config do |config|
39
+ config.ragic_api_url = 'your ragic_api_url'
40
+ config.ragic_api_key = 'Basic your_ragic_api_key'
41
+ end
42
+ ```
43
+
44
+ **Note: What you need to do is use the field ids of the fields as name, and the values that you want to insert as parameter values.**
45
+
46
+ See here [Ragic API Documents](https://www.ragic.com/intl/en/doc-api/15/Creating-a-New-Entry).
47
+
48
+ ### Create Entry
49
+
50
+ ```ruby
51
+ params = {
52
+ '1000001' => 'Project Name',
53
+ '1000002' => '15000'
54
+ }
55
+ RagicClient.create params
56
+ ```
57
+
58
+ ### Update Entry
59
+
60
+ ```ruby
61
+ ragic_id = 1
62
+ params = {
63
+ '1000001' => 'Project Name Update'
64
+ }
65
+ RagicClient.update ragic_id, params
66
+ ```
67
+
68
+ ### Delete Entry
69
+
70
+ ```ruby
71
+ RagicClient.delete 1
72
+ ```
73
+
74
+ ### Find Entry by id
75
+
76
+ ```ruby
77
+ RagicClient.find 1
78
+ ```
79
+
80
+ ### Find Entry by field id and value
81
+
82
+ ```ruby
83
+ RagicClient.find_by { '1000001' => 'Project Name' }
84
+ ```
85
+
86
+ ## Development
87
+
88
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
89
+
90
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
91
+
92
+ ## Contributing
93
+
94
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/ragic_client. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
95
+
96
+ ## License
97
+
98
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
99
+
100
+ ## Code of Conduct
101
+
102
+ Everyone interacting in the EmailDetected project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/[USERNAME]/ragic_client/blob/master/CODE_OF_CONDUCT.md).
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+ task :default => :spec
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "ragic_client"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start(__FILE__)
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,130 @@
1
+ require 'ragic_client/version'
2
+ require 'httparty'
3
+ require 'json'
4
+
5
+ module RagicClient
6
+ class Error < StandardError; end
7
+ module Config
8
+ class << self
9
+ attr_accessor :ragic_api_url
10
+ attr_accessor :ragic_api_key
11
+
12
+ def setup
13
+ @ragic_api_url = ragic_api_url
14
+ @ragic_api_key = ragic_api_key
15
+ end
16
+ end
17
+ self.setup
18
+ end
19
+
20
+ def self.config(&block)
21
+ if block_given?
22
+ block.call(RagicClient::Config)
23
+ else
24
+ RagicClient::Config
25
+ end
26
+ end
27
+
28
+ def self.ragic_base_api_url(ragic_id = nil)
29
+ return "#{RagicClient::Config.ragic_api_url}/#{ragic_id}" if ragic_id
30
+
31
+ RagicClient::Config.ragic_api_url
32
+ end
33
+
34
+ def self.headers
35
+ {
36
+ 'Content-Type': 'application/json',
37
+ 'Authorization': RagicClient::Config.ragic_api_key
38
+ }
39
+ end
40
+
41
+ def self.find(ragic_id)
42
+ opts = {
43
+ headers: RagicClient.headers
44
+ }
45
+ beauty_body HTTParty.get(ragic_base_api_url(ragic_id), opts), ragic_id: ragic_id
46
+ end
47
+
48
+ # https://www.ragic.com/intl/en/doc-api/9/Filter-Conditions
49
+ def self.find_by(condition_hash = {})
50
+ opts = {
51
+ headers: RagicClient.headers
52
+ }
53
+ api_url = [ragic_base_api_url]
54
+ return {
55
+ status: false,
56
+ msg: 'Invalid conditions params'
57
+ } unless condition_hash.is_a?(Hash)
58
+ index = 0
59
+ condition_hash.each do |key, value|
60
+ api_url.push("#{index.zero? ? '?' : '&'}where=#{key},eq,#{value}")
61
+ index += 1
62
+ end
63
+ api_url = api_url.join('')
64
+ beauty_body HTTParty.get(api_url, opts)
65
+ end
66
+
67
+ # https://www.ragic.com/intl/en/doc-api/20/Deleting-an-entry
68
+ def self.delete(ragic_id)
69
+ opts = {
70
+ headers: RagicClient.headers
71
+ }
72
+ beauty_body HTTParty.delete(ragic_base_api_url(ragic_id), opts)
73
+ end
74
+
75
+ # https://www.ragic.com/intl/en/doc-api/15/Creating-a-New-Entry
76
+ def self.create(params = {})
77
+ ragic_params = { doDefaultValue: true, doLinkLoad: true }
78
+ ragic_params = ragic_params.merge!(params)
79
+ opts = {
80
+ headers: RagicClient.headers,
81
+ body: ragic_params.to_json
82
+ }
83
+ beauty_body HTTParty.post(ragic_base_api_url, opts)
84
+ end
85
+
86
+ # https://www.ragic.com/intl/en/doc-api/16/Modifying-an-Entry
87
+ def self.update(ragic_id, params = {})
88
+ opts = {
89
+ headers: RagicClient.headers,
90
+ body: params.to_json
91
+ }
92
+ beauty_body HTTParty.post(ragic_base_api_url(ragic_id), opts), is_update: true
93
+ end
94
+
95
+ def self.beauty_body(response, options = {})
96
+ success = false
97
+ status_code = response.code
98
+ if status_code == 200
99
+ begin
100
+ body = JSON.parse(response.body) || {}
101
+ data =
102
+ if options[:is_update]
103
+ body['data']
104
+ elsif options[:ragic_id]
105
+ body[options[:ragic_id].to_s]
106
+ else
107
+ body
108
+ end
109
+ success = true if body['status'] != 'ERROR'
110
+ msg = 'Ragic ID Not Found.' if ragic_id
111
+ msg = body['msg']&.gsub('&nbsp;', '') if data
112
+ rescue
113
+ msg = 'Error!'
114
+ end
115
+ else
116
+ begin
117
+ body = JSON.parse(response.body)
118
+ msg = body['msg']&.gsub('&nbsp;', '')
119
+ rescue
120
+ msg = 'Error!'
121
+ end
122
+ end
123
+ {
124
+ status_code: status_code,
125
+ success: success,
126
+ data: data,
127
+ msg: msg
128
+ }.delete_if { |_k, v| v.nil? }
129
+ end
130
+ end
@@ -0,0 +1,3 @@
1
+ module RagicClient
2
+ VERSION = "0.1.3"
3
+ end
@@ -0,0 +1,26 @@
1
+ require_relative 'lib/ragic_client/version'
2
+
3
+ Gem::Specification.new do |spec|
4
+ spec.name = "ragic_client"
5
+ spec.version = RagicClient::VERSION
6
+ spec.authors = ["Derek Nguyen"]
7
+ spec.email = ["derek.nguyen.269@gmail.com"]
8
+
9
+ spec.summary = 'RagicClient'
10
+ spec.description = 'RagicClient is a simple tool integrate with RAGIC system.'
11
+ spec.homepage = "https://github.com/dereknguyen269/ragic_client"
12
+ spec.required_ruby_version = Gem::Requirement.new(">= 2.3.0")
13
+
14
+ spec.metadata["homepage_uri"] = spec.homepage
15
+ spec.metadata["source_code_uri"] = "https://github.com/dereknguyen269/ragic_client"
16
+ spec.metadata["changelog_uri"] = "https://github.com/dereknguyen269/ragic_client/CHANGELOG.md"
17
+
18
+ # Specify which files should be added to the gem when it is released.
19
+ # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
20
+ spec.files = Dir.chdir(File.expand_path('..', __FILE__)) do
21
+ `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
22
+ end
23
+ spec.bindir = "exe"
24
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
25
+ spec.require_paths = ["lib"]
26
+ end
metadata ADDED
@@ -0,0 +1,56 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: ragic_client
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.3
5
+ platform: ruby
6
+ authors:
7
+ - Derek Nguyen
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2020-05-31 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: RagicClient is a simple tool integrate with RAGIC system.
14
+ email:
15
+ - derek.nguyen.269@gmail.com
16
+ executables: []
17
+ extensions: []
18
+ extra_rdoc_files: []
19
+ files:
20
+ - ".gitignore"
21
+ - CHANGELOG.md
22
+ - Gemfile
23
+ - Gemfile.lock
24
+ - README.md
25
+ - Rakefile
26
+ - bin/console
27
+ - bin/setup
28
+ - lib/ragic_client.rb
29
+ - lib/ragic_client/version.rb
30
+ - ragic_client.gemspec
31
+ homepage: https://github.com/dereknguyen269/ragic_client
32
+ licenses: []
33
+ metadata:
34
+ homepage_uri: https://github.com/dereknguyen269/ragic_client
35
+ source_code_uri: https://github.com/dereknguyen269/ragic_client
36
+ changelog_uri: https://github.com/dereknguyen269/ragic_client/CHANGELOG.md
37
+ post_install_message:
38
+ rdoc_options: []
39
+ require_paths:
40
+ - lib
41
+ required_ruby_version: !ruby/object:Gem::Requirement
42
+ requirements:
43
+ - - ">="
44
+ - !ruby/object:Gem::Version
45
+ version: 2.3.0
46
+ required_rubygems_version: !ruby/object:Gem::Requirement
47
+ requirements:
48
+ - - ">="
49
+ - !ruby/object:Gem::Version
50
+ version: '0'
51
+ requirements: []
52
+ rubygems_version: 3.1.2
53
+ signing_key:
54
+ specification_version: 4
55
+ summary: RagicClient
56
+ test_files: []