moesif_api 1.2.8 → 1.2.9

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4c634394e829a513470949c40b4bc20708a9964226230dbaa3426cbde75c2e50
4
- data.tar.gz: f9d9c8d20b406e3c7aeb7babb6a3db9836a45f27bda57140c60a25a6a534c295
3
+ metadata.gz: b1f73da8a0a7ab951367a0bdeca1043aa8daaf0d64991967257dd58aa1543bf2
4
+ data.tar.gz: d4f70c81fd5f3b6e7a7b8e37663be2f3370fb8064e8de5ecb2e4c7c042713acc
5
5
  SHA512:
6
- metadata.gz: b18941a1bff1df72bdd28125125300c497bf733abb3b0d5ca164e180b1e7b09e6379e716a93a39ce1af2580fe1e355ede89a012fdbebddf946e7d061d388860d
7
- data.tar.gz: ad384326772cf63e2e18a5abc7cdf1ccc57e4371bf42bcbead3ec14db3ddea51638dcc5c881c7e8f31056f1204cb08d7c679a56a43794f892e42cf4d311f35b7
6
+ metadata.gz: b17284c40ccadd2859b73d71af0bfdb71b23bef6b05018ccd210788d2cae0ac06ac00e6b9f1b79c5f35917fc4edf795edd09bbe93e64b4219f73df4f51533a03
7
+ data.tar.gz: 02d6c4aaf81b237347104567f8f9c5388ae16416f93523797a650acbe788f5fe266e0e20f9f52650fc38c3a15b2cedf435929c2c64066e10e11ce078b65599fc
data/LICENSE~ ADDED
@@ -0,0 +1,216 @@
1
+ Copyright (c) 2018 Moesif, Inc
2
+
3
+ Licensed under the Apache License, Version 2.0 (the "License");
4
+ you may not use this file except in compliance with the License.
5
+ You may obtain a copy of the License at
6
+
7
+ http://www.apache.org/licenses/LICENSE-2.0
8
+
9
+ Unless required by applicable law or agreed to in writing, software
10
+ distributed under the License is distributed on an "AS IS" BASIS,
11
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ See the License for the specific language governing permissions and
13
+ limitations under the License.
14
+
15
+
16
+ Apache License
17
+ Version 2.0, January 2004
18
+ http://www.apache.org/licenses/
19
+
20
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
21
+
22
+ 1. Definitions.
23
+
24
+ "License" shall mean the terms and conditions for use, reproduction,
25
+ and distribution as defined by Sections 1 through 9 of this document.
26
+
27
+ "Licensor" shall mean the copyright owner or entity authorized by
28
+ the copyright owner that is granting the License.
29
+
30
+ "Legal Entity" shall mean the union of the acting entity and all
31
+ other entities that control, are controlled by, or are under common
32
+ control with that entity. For the purposes of this definition,
33
+ "control" means (i) the power, direct or indirect, to cause the
34
+ direction or management of such entity, whether by contract or
35
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
36
+ outstanding shares, or (iii) beneficial ownership of such entity.
37
+
38
+ "You" (or "Your") shall mean an individual or Legal Entity
39
+ exercising permissions granted by this License.
40
+
41
+ "Source" form shall mean the preferred form for making modifications,
42
+ including but not limited to software source code, documentation
43
+ source, and configuration files.
44
+
45
+ "Object" form shall mean any form resulting from mechanical
46
+ transformation or translation of a Source form, including but
47
+ not limited to compiled object code, generated documentation,
48
+ and conversions to other media types.
49
+
50
+ "Work" shall mean the work of authorship, whether in Source or
51
+ Object form, made available under the License, as indicated by a
52
+ copyright notice that is included in or attached to the work
53
+ (an example is provided in the Appendix below).
54
+
55
+ "Derivative Works" shall mean any work, whether in Source or Object
56
+ form, that is based on (or derived from) the Work and for which the
57
+ editorial revisions, annotations, elaborations, or other modifications
58
+ represent, as a whole, an original work of authorship. For the purposes
59
+ of this License, Derivative Works shall not include works that remain
60
+ separable from, or merely link (or bind by name) to the interfaces of,
61
+ the Work and Derivative Works thereof.
62
+
63
+ "Contribution" shall mean any work of authorship, including
64
+ the original version of the Work and any modifications or additions
65
+ to that Work or Derivative Works thereof, that is intentionally
66
+ submitted to Licensor for inclusion in the Work by the copyright owner
67
+ or by an individual or Legal Entity authorized to submit on behalf of
68
+ the copyright owner. For the purposes of this definition, "submitted"
69
+ means any form of electronic, verbal, or written communication sent
70
+ to the Licensor or its representatives, including but not limited to
71
+ communication on electronic mailing lists, source code control systems,
72
+ and issue tracking systems that are managed by, or on behalf of, the
73
+ Licensor for the purpose of discussing and improving the Work, but
74
+ excluding communication that is conspicuously marked or otherwise
75
+ designated in writing by the copyright owner as "Not a Contribution."
76
+
77
+ "Contributor" shall mean Licensor and any individual or Legal Entity
78
+ on behalf of whom a Contribution has been received by Licensor and
79
+ subsequently incorporated within the Work.
80
+
81
+ 2. Grant of Copyright License. Subject to the terms and conditions of
82
+ this License, each Contributor hereby grants to You a perpetual,
83
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
84
+ copyright license to reproduce, prepare Derivative Works of,
85
+ publicly display, publicly perform, sublicense, and distribute the
86
+ Work and such Derivative Works in Source or Object form.
87
+
88
+ 3. Grant of Patent License. Subject to the terms and conditions of
89
+ this License, each Contributor hereby grants to You a perpetual,
90
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
91
+ (except as stated in this section) patent license to make, have made,
92
+ use, offer to sell, sell, import, and otherwise transfer the Work,
93
+ where such license applies only to those patent claims licensable
94
+ by such Contributor that are necessarily infringed by their
95
+ Contribution(s) alone or by combination of their Contribution(s)
96
+ with the Work to which such Contribution(s) was submitted. If You
97
+ institute patent litigation against any entity (including a
98
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
99
+ or a Contribution incorporated within the Work constitutes direct
100
+ or contributory patent infringement, then any patent licenses
101
+ granted to You under this License for that Work shall terminate
102
+ as of the date such litigation is filed.
103
+
104
+ 4. Redistribution. You may reproduce and distribute copies of the
105
+ Work or Derivative Works thereof in any medium, with or without
106
+ modifications, and in Source or Object form, provided that You
107
+ meet the following conditions:
108
+
109
+ (a) You must give any other recipients of the Work or
110
+ Derivative Works a copy of this License; and
111
+
112
+ (b) You must cause any modified files to carry prominent notices
113
+ stating that You changed the files; and
114
+
115
+ (c) You must retain, in the Source form of any Derivative Works
116
+ that You distribute, all copyright, patent, trademark, and
117
+ attribution notices from the Source form of the Work,
118
+ excluding those notices that do not pertain to any part of
119
+ the Derivative Works; and
120
+
121
+ (d) If the Work includes a "NOTICE" text file as part of its
122
+ distribution, then any Derivative Works that You distribute must
123
+ include a readable copy of the attribution notices contained
124
+ within such NOTICE file, excluding those notices that do not
125
+ pertain to any part of the Derivative Works, in at least one
126
+ of the following places: within a NOTICE text file distributed
127
+ as part of the Derivative Works; within the Source form or
128
+ documentation, if provided along with the Derivative Works; or,
129
+ within a display generated by the Derivative Works, if and
130
+ wherever such third-party notices normally appear. The contents
131
+ of the NOTICE file are for informational purposes only and
132
+ do not modify the License. You may add Your own attribution
133
+ notices within Derivative Works that You distribute, alongside
134
+ or as an addendum to the NOTICE text from the Work, provided
135
+ that such additional attribution notices cannot be construed
136
+ as modifying the License.
137
+
138
+ You may add Your own copyright statement to Your modifications and
139
+ may provide additional or different license terms and conditions
140
+ for use, reproduction, or distribution of Your modifications, or
141
+ for any such Derivative Works as a whole, provided Your use,
142
+ reproduction, and distribution of the Work otherwise complies with
143
+ the conditions stated in this License.
144
+
145
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
146
+ any Contribution intentionally submitted for inclusion in the Work
147
+ by You to the Licensor shall be under the terms and conditions of
148
+ this License, without any additional terms or conditions.
149
+ Notwithstanding the above, nothing herein shall supersede or modify
150
+ the terms of any separate license agreement you may have executed
151
+ with Licensor regarding such Contributions.
152
+
153
+ 6. Trademarks. This License does not grant permission to use the trade
154
+ names, trademarks, service marks, or product names of the Licensor,
155
+ except as required for reasonable and customary use in describing the
156
+ origin of the Work and reproducing the content of the NOTICE file.
157
+
158
+ 7. Disclaimer of Warranty. Unless required by applicable law or
159
+ agreed to in writing, Licensor provides the Work (and each
160
+ Contributor provides its Contributions) on an "AS IS" BASIS,
161
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
162
+ implied, including, without limitation, any warranties or conditions
163
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
164
+ PARTICULAR PURPOSE. You are solely responsible for determining the
165
+ appropriateness of using or redistributing the Work and assume any
166
+ risks associated with Your exercise of permissions under this License.
167
+
168
+ 8. Limitation of Liability. In no event and under no legal theory,
169
+ whether in tort (including negligence), contract, or otherwise,
170
+ unless required by applicable law (such as deliberate and grossly
171
+ negligent acts) or agreed to in writing, shall any Contributor be
172
+ liable to You for damages, including any direct, indirect, special,
173
+ incidental, or consequential damages of any character arising as a
174
+ result of this License or out of the use or inability to use the
175
+ Work (including but not limited to damages for loss of goodwill,
176
+ work stoppage, computer failure or malfunction, or any and all
177
+ other commercial damages or losses), even if such Contributor
178
+ has been advised of the possibility of such damages.
179
+
180
+ 9. Accepting Warranty or Additional Liability. While redistributing
181
+ the Work or Derivative Works thereof, You may choose to offer,
182
+ and charge a fee for, acceptance of support, warranty, indemnity,
183
+ or other liability obligations and/or rights consistent with this
184
+ License. However, in accepting such obligations, You may act only
185
+ on Your own behalf and on Your sole responsibility, not on behalf
186
+ of any other Contributor, and only if You agree to indemnify,
187
+ defend, and hold each Contributor harmless for any liability
188
+ incurred by, or claims asserted against, such Contributor by reason
189
+ of your accepting any such warranty or additional liability.
190
+
191
+ END OF TERMS AND CONDITIONS
192
+
193
+ APPENDIX: How to apply the Apache License to your work.
194
+
195
+ To apply the Apache License to your work, attach the following
196
+ boilerplate notice, with the fields enclosed by brackets "[]"
197
+ replaced with your own identifying information. (Don't include
198
+ the brackets!) The text should be enclosed in the appropriate
199
+ comment syntax for the file format. We also recommend that a
200
+ file or class name and description of purpose be included on the
201
+ same "printed page" as the copyright notice for easier
202
+ identification within third-party archives.
203
+
204
+ Copyright [yyyy] [name of copyright owner]
205
+
206
+ Licensed under the Apache License, Version 2.0 (the "License");
207
+ you may not use this file except in compliance with the License.
208
+ You may obtain a copy of the License at
209
+
210
+ http://www.apache.org/licenses/LICENSE-2.0
211
+
212
+ Unless required by applicable law or agreed to in writing, software
213
+ distributed under the License is distributed on an "AS IS" BASIS,
214
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
215
+ See the License for the specific language governing permissions and
216
+ limitations under the License.
data/README.md CHANGED
@@ -30,8 +30,15 @@ gem install moesif_api
30
30
 
31
31
  After having installed the gem, you can easily use the SDK following these steps.
32
32
 
33
- 1. Create a "moesif_api_test.rb" file in the root directory.
34
- 2. Use any controller as follows:
33
+ Your Moesif Application Id can be found in the [_Moesif Portal_](https://www.moesif.com/).
34
+ After signing up for a Moesif account, your Moesif Application Id will be displayed during the onboarding steps.
35
+
36
+ You can always find your Moesif Application Id at any time by logging
37
+ into the [_Moesif Portal_](https://www.moesif.com/), click on the top right menu,
38
+ and then clicking _Installation_.
39
+
40
+ ### Create Event
41
+
35
42
  ```ruby
36
43
  require 'moesif_api'
37
44
 
@@ -81,7 +88,7 @@ metadata = JSON.parse('{'\
81
88
  '}')
82
89
 
83
90
  event_req = EventRequestModel.new()
84
- event_req.time = "2016-09-09T04:45:42.914"
91
+ event_req.time = "2019-09-09T04:45:42.914"
85
92
  event_req.uri = "https://api.acmeinc.com/items/reviews/"
86
93
  event_req.verb = "PATCH"
87
94
  event_req.api_version = "1.1.0"
@@ -90,7 +97,7 @@ event_req.headers = req_headers
90
97
  event_req.body = req_body
91
98
 
92
99
  event_rsp = EventResponseModel.new()
93
- event_rsp.time = "2016-09-09T04:45:42.914"
100
+ event_rsp.time = "2019-09-09T04:45:42.914"
94
101
  event_rsp.status = 500
95
102
  event_rsp.headers = rsp_headers
96
103
  event_rsp.body = rsp_body
@@ -107,7 +114,7 @@ event_model.metadata = metadata
107
114
  response = api_controller.create_event(event_model)
108
115
  ```
109
116
 
110
- ### update user
117
+ ### Update User
111
118
 
112
119
  You can also update the metadata for each user. The only required field is user_id
113
120
 
@@ -121,18 +128,23 @@ metadata = JSON.parse('{'\
121
128
  '"custom": "testdata"'\
122
129
  '}')
123
130
 
131
+ campaign_model = CampaignModel.new()
132
+ campaign_model.utm_source = "Newsletter"
133
+ campaign_model.utm_medium = "Email"
134
+
124
135
  user_model = UserModel.new()
125
136
  user_model.modified_time = Time.now.utc.iso8601 # option, default now.
126
137
  user_model.user_id = "12345" #only required field.
127
138
  user_model.company_id = "67890"
128
139
  user_model.metadata = metadata
140
+ user_model.campaign = campaign_model
129
141
 
130
142
  # Perform the API call through the SDK function
131
143
  response = api_controller.update_user(user_model)
132
144
 
133
145
  ```
134
146
 
135
- ### update company
147
+ ### Update Company
136
148
 
137
149
  You can also update the metadata for each company. The only required field is company_id
138
150
 
@@ -146,10 +158,15 @@ metadata = JSON.parse('{'\
146
158
  '"location": "United States"'\
147
159
  '}')
148
160
 
161
+ campaign_model = CampaignModel.new()
162
+ campaign_model.utm_source = "Adwords"
163
+ campaign_model.utm_medium = "Twitter"
164
+
149
165
  company_model = CompanyModel.new()
150
166
  company_model.modified_time = Time.now.utc.iso8601 # option, default now.
151
167
  company_model.company_id = "12345" #only required field.
152
168
  company_model.metadata = metadata
169
+ company_model.campaign = campaign_model
153
170
 
154
171
  # Perform the API call through the SDK function
155
172
  response = api_controller.update_company(company_model)
data/lib/moesif_api.rb CHANGED
@@ -28,6 +28,7 @@ require_relative 'moesif_api/models/event_response_model.rb'
28
28
  require_relative 'moesif_api/models/status_model.rb'
29
29
  require_relative 'moesif_api/models/user_model.rb'
30
30
  require_relative 'moesif_api/models/company_model.rb'
31
+ require_relative 'moesif_api/models/campaign_model.rb'
31
32
 
32
33
  # Controllers
33
34
  require_relative 'moesif_api/controllers/base_controller.rb'
@@ -8,7 +8,7 @@ module MoesifApi
8
8
  # Your Application Id for authentication/authorization
9
9
  @application_id = 'SET_ME'
10
10
 
11
- @version = '1.2.8'
11
+ @version = '1.2.9'
12
12
 
13
13
  # create the getters and setters
14
14
  class << self
@@ -0,0 +1,20 @@
1
+
2
+
3
+ module MoesifApi
4
+ class Configuration
5
+ # The base Uri for API calls
6
+ @base_uri = 'https://api.moesif.net'
7
+
8
+ # Your Application Id for authentication/authorization
9
+ @application_id = 'SET_ME'
10
+
11
+ @version = '1.2.2'
12
+
13
+ # create the getters and setters
14
+ class << self
15
+ attr_accessor :base_uri
16
+ attr_accessor :application_id
17
+ attr_accessor :version
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,98 @@
1
+
2
+ module MoesifApi
3
+ class CampaignModel < BaseModel
4
+
5
+ # the utm source
6
+ # @return [String]
7
+ attr_accessor :utm_source
8
+
9
+ # the utm medium
10
+ # @return [String]
11
+ attr_accessor :utm_medium
12
+
13
+ # the utm campaign
14
+ # @return [String]
15
+ attr_accessor :utm_campaign
16
+
17
+ # the utm term
18
+ # @return [String]
19
+ attr_accessor :utm_term
20
+
21
+ # the utm content
22
+ # @return [String]
23
+ attr_accessor :utm_content
24
+
25
+ # the referrer
26
+ # @return [String]
27
+ attr_accessor :referrer
28
+
29
+ # the referring domain
30
+ # @return [String]
31
+ attr_accessor :referring_domain
32
+
33
+ # the gclid
34
+ # @return [String]
35
+ attr_accessor :gclid
36
+
37
+ # A mapping from model property names to API property names
38
+ def self.names
39
+ if @hash.nil?
40
+ @hash = {}
41
+ @hash["utm_source"] = "utm_source"
42
+ @hash["utm_medium"] = "utm_medium"
43
+ @hash["utm_campaign"] = "utm_campaign"
44
+ @hash["utm_term"] = "utm_term"
45
+ @hash["utm_content"] = "utm_content"
46
+ @hash["referrer"] = "referrer"
47
+ @hash["referring_domain"] = "referring_domain"
48
+ @hash["gclid"] = "gclid"
49
+ end
50
+ @hash
51
+ end
52
+
53
+ def initialize(utm_source = nil,
54
+ utm_medium = nil,
55
+ utm_campaign = nil,
56
+ utm_term = nil,
57
+ utm_content = nil,
58
+ referrer = nil,
59
+ referring_domain = nil,
60
+ gclid = nil)
61
+ @utm_source = utm_source
62
+ @utm_medium = utm_medium
63
+ @utm_campaign = utm_campaign
64
+ @utm_term = utm_term
65
+ @utm_content = utm_content
66
+ @referrer = referrer
67
+ @referring_domain = referring_domain
68
+ @gclid = gclid
69
+ end
70
+
71
+ # Creates an instance of the object from a hash
72
+ def self.from_hash(hash)
73
+ if hash == nil
74
+ nil
75
+ else
76
+ # Extract variables from the hash
77
+ utm_source = hash["utm_source"]
78
+ utm_medium = hash["utm_medium"]
79
+ utm_campaign = hash["utm_campaign"]
80
+ utm_term = hash["utm_term"]
81
+ utm_content = hash["utm_content"]
82
+ referrer = hash["referrer"]
83
+ referring_domain = hash["referring_domain"]
84
+ gclid = hash["gclid"]
85
+
86
+ # Create object from extracted values
87
+ CampaignModel.new(utm_source,
88
+ utm_medium,
89
+ utm_campaign,
90
+ utm_term,
91
+ utm_content,
92
+ referrer,
93
+ referring_domain,
94
+ gclid)
95
+ end
96
+ end
97
+ end
98
+ end
@@ -28,6 +28,10 @@ module MoesifApi
28
28
  # @return [Object]
29
29
  attr_accessor :metadata
30
30
 
31
+ # campaign object
32
+ # @return [CampaignModel]
33
+ attr_accessor :campaign
34
+
31
35
  # A mapping from model property names to API property names
32
36
  def self.names
33
37
  if @hash.nil?
@@ -38,6 +42,7 @@ module MoesifApi
38
42
  @hash["session_token"] = "session_token"
39
43
  @hash["company_domain"] = "company_domain"
40
44
  @hash["metadata"] = "metadata"
45
+ @hash["campaign"] = "campaign"
41
46
  end
42
47
  @hash
43
48
  end
@@ -47,13 +52,15 @@ module MoesifApi
47
52
  ip_address = nil,
48
53
  session_token = nil,
49
54
  company_domain = nil,
50
- metadata = nil)
55
+ metadata = nil,
56
+ campaign = nil)
51
57
  @company_id = company_id
52
58
  @modified_time = modified_time
53
59
  @ip_address = ip_address
54
60
  @session_token = session_token
55
61
  @company_domain = company_domain
56
62
  @metadata = metadata
63
+ @campaign = campaign
57
64
  end
58
65
 
59
66
  # Creates an instance of the object from a hash
@@ -68,6 +75,7 @@ module MoesifApi
68
75
  session_token = hash["session_token"]
69
76
  company_domain = hash["company_domain"]
70
77
  metadata = hash["metadata"]
78
+ campaign = CampaignModel.from_hash(hash["campaign"]) if hash["campaign"]
71
79
 
72
80
  # Create object from extracted values
73
81
  CompanyModel.new(company_id,
@@ -75,7 +83,8 @@ module MoesifApi
75
83
  ip_address,
76
84
  session_token,
77
85
  company_domain,
78
- metadata)
86
+ metadata,
87
+ campaign)
79
88
  end
80
89
  end
81
90
  end
@@ -32,6 +32,10 @@ module MoesifApi
32
32
  # @return [Object]
33
33
  attr_accessor :metadata
34
34
 
35
+ # campaign object
36
+ # @return [CampaignModel]
37
+ attr_accessor :campaign
38
+
35
39
  # A mapping from model property names to API property names
36
40
  def self.names
37
41
  if @hash.nil?
@@ -43,6 +47,7 @@ module MoesifApi
43
47
  @hash["session_token"] = "session_token"
44
48
  @hash["user_agent_string"] = "user_agent_string"
45
49
  @hash["metadata"] = "metadata"
50
+ @hash["campaign"] = "campaign"
46
51
  end
47
52
  @hash
48
53
  end
@@ -53,7 +58,8 @@ module MoesifApi
53
58
  ip_address = nil,
54
59
  session_token = nil,
55
60
  user_agent_string = nil,
56
- metadata = nil)
61
+ metadata = nil,
62
+ campaign = nil)
57
63
  @user_id = user_id
58
64
  @company_id = company_id
59
65
  @modified_time = modified_time
@@ -61,6 +67,7 @@ module MoesifApi
61
67
  @session_token = session_token
62
68
  @user_agent_string = user_agent_string
63
69
  @metadata = metadata
70
+ @campaign = campaign
64
71
  end
65
72
 
66
73
  # Creates an instance of the object from a hash
@@ -76,6 +83,7 @@ module MoesifApi
76
83
  session_token = hash["session_token"]
77
84
  user_agent_string = hash["user_agent_string"]
78
85
  metadata = hash["metadata"]
86
+ campaign = CampaignModel.from_hash(hash["campaign"]) if hash["campaign"]
79
87
 
80
88
  # Create object from extracted values
81
89
  UserModel.new(user_id,
@@ -84,7 +92,8 @@ module MoesifApi
84
92
  ip_address,
85
93
  session_token,
86
94
  user_agent_string,
87
- metadata)
95
+ metadata,
96
+ campaign)
88
97
  end
89
98
  end
90
99
  end
@@ -113,11 +113,16 @@ class ApiControllerTests < ControllerTestBase
113
113
  '"custom": "testdata"'\
114
114
  '}')
115
115
 
116
+ campaign_model = CampaignModel.new()
117
+ campaign_model.utm_source = "Newsletter"
118
+ campaign_model.utm_medium = "Email"
119
+
116
120
  user_model = UserModel.new()
117
121
  user_model.modified_time = Time.now.utc.iso8601
118
122
  user_model.user_id = "12345"
119
123
  user_model.company_id = "67890"
120
124
  user_model.metadata = metadata
125
+ user_model.campaign = campaign_model
121
126
 
122
127
  # Perform the API call through the SDK function
123
128
  self.class.controller.update_user(user_model)
@@ -171,9 +176,14 @@ class ApiControllerTests < ControllerTestBase
171
176
  def test_update_company()
172
177
  # Parameters for the API call
173
178
 
179
+ campaign_model = CampaignModel.new()
180
+ campaign_model.utm_source = "Adwords"
181
+ campaign_model.utm_medium = "Twitter"
182
+
174
183
  company_model = CompanyModel.new()
175
184
  company_model.modified_time = Time.now.utc.iso8601
176
185
  company_model.company_id = "12345"
186
+ company_model.campaign = campaign_model
177
187
 
178
188
  # Perform the API call through the SDK function
179
189
  self.class.controller.update_company(company_model)
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: moesif_api
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.2.8
4
+ version: 1.2.9
5
5
  platform: ruby
6
6
  authors:
7
7
  - Moesif, Inc
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2019-08-21 00:00:00.000000000 Z
12
+ date: 2019-11-15 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: test-unit
@@ -60,10 +60,12 @@ extensions: []
60
60
  extra_rdoc_files: []
61
61
  files:
62
62
  - LICENSE
63
+ - LICENSE~
63
64
  - README.md
64
65
  - lib/moesif_api.rb
65
66
  - lib/moesif_api/api_helper.rb
66
67
  - lib/moesif_api/configuration.rb
68
+ - lib/moesif_api/configuration.rb~
67
69
  - lib/moesif_api/controllers/api_controller.rb
68
70
  - lib/moesif_api/controllers/base_controller.rb
69
71
  - lib/moesif_api/controllers/health_controller.rb
@@ -76,6 +78,7 @@ files:
76
78
  - lib/moesif_api/http/http_response.rb
77
79
  - lib/moesif_api/http/unirest_client.rb
78
80
  - lib/moesif_api/models/base_model.rb
81
+ - lib/moesif_api/models/campaign_model.rb
79
82
  - lib/moesif_api/models/company_model.rb
80
83
  - lib/moesif_api/models/event_model.rb
81
84
  - lib/moesif_api/models/event_request_model.rb
@@ -106,7 +109,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
106
109
  - !ruby/object:Gem::Version
107
110
  version: '0'
108
111
  requirements: []
109
- rubygems_version: 3.0.1
112
+ rubyforge_project:
113
+ rubygems_version: 2.7.7
110
114
  signing_key:
111
115
  specification_version: 4
112
116
  summary: moesif_api