embulk-input-marketo 0.5.6 → 0.5.7.alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/PULL_REQUEST_TEMPLATE.md +37 -0
- data/.gitignore +11 -2
- data/.travis.yml +5 -45
- data/LICENSE.txt +21 -0
- data/README.md +14 -65
- data/build.gradle +102 -0
- data/config/checkstyle/checkstyle.xml +128 -0
- data/config/checkstyle/default.xml +108 -0
- data/gradle/wrapper/gradle-wrapper.jar +0 -0
- data/gradle/wrapper/gradle-wrapper.properties +6 -0
- data/gradlew +169 -0
- data/gradlew.bat +84 -0
- data/lib/embulk/input/marketo.rb +3 -0
- data/settings.gradle +1 -0
- data/src/main/java/org/embulk/input/marketo/CsvTokenizer.java +677 -0
- data/src/main/java/org/embulk/input/marketo/MarketoInputPlugin.java +15 -0
- data/src/main/java/org/embulk/input/marketo/MarketoInputPluginDelegate.java +77 -0
- data/src/main/java/org/embulk/input/marketo/MarketoService.java +30 -0
- data/src/main/java/org/embulk/input/marketo/MarketoServiceImpl.java +176 -0
- data/src/main/java/org/embulk/input/marketo/MarketoUtils.java +172 -0
- data/src/main/java/org/embulk/input/marketo/delegate/ActivityBulkExtractInputPlugin.java +63 -0
- data/src/main/java/org/embulk/input/marketo/delegate/CampaignInputPlugin.java +67 -0
- data/src/main/java/org/embulk/input/marketo/delegate/LeadBulkExtractInputPlugin.java +61 -0
- data/src/main/java/org/embulk/input/marketo/delegate/LeadWithListInputPlugin.java +58 -0
- data/src/main/java/org/embulk/input/marketo/delegate/LeadWithProgramInputPlugin.java +56 -0
- data/src/main/java/org/embulk/input/marketo/delegate/MarketoBaseBulkExtractInputPlugin.java +260 -0
- data/src/main/java/org/embulk/input/marketo/delegate/MarketoBaseInputPluginDelegate.java +69 -0
- data/src/main/java/org/embulk/input/marketo/exception/MarketoAPIException.java +30 -0
- data/src/main/java/org/embulk/input/marketo/model/MarketoAccessTokenResponse.java +92 -0
- data/src/main/java/org/embulk/input/marketo/model/MarketoBulkExtractRequest.java +59 -0
- data/src/main/java/org/embulk/input/marketo/model/MarketoError.java +40 -0
- data/src/main/java/org/embulk/input/marketo/model/MarketoField.java +91 -0
- data/src/main/java/org/embulk/input/marketo/model/MarketoResponse.java +81 -0
- data/src/main/java/org/embulk/input/marketo/model/filter/DateRangeFilter.java +31 -0
- data/src/main/java/org/embulk/input/marketo/model/filter/ListFilter.java +10 -0
- data/src/main/java/org/embulk/input/marketo/model/filter/MarketoFilter.java +8 -0
- data/src/main/java/org/embulk/input/marketo/rest/MarketoBaseRestClient.java +226 -0
- data/src/main/java/org/embulk/input/marketo/rest/MarketoFileResponseEntityReader.java +69 -0
- data/src/main/java/org/embulk/input/marketo/rest/MarketoRESTEndpoint.java +44 -0
- data/src/main/java/org/embulk/input/marketo/rest/MarketoResponseJetty92EntityReader.java +88 -0
- data/src/main/java/org/embulk/input/marketo/rest/MarketoRestClient.java +332 -0
- data/src/main/java/org/embulk/input/marketo/rest/RecordPagingIterable.java +130 -0
- data/src/test/java/org/embulk/input/marketo/TestMarketoInputPlugin.java +5 -0
- data/src/test/java/org/embulk/input/marketo/rest/MarketoBaseRestClientTest.java +220 -0
- metadata +65 -222
- data/.ruby-version +0 -1
- data/.travis.yml.erb +0 -42
- data/Gemfile +0 -3
- data/LICENSE +0 -13
- data/Rakefile +0 -20
- data/embulk-input-marketo.gemspec +0 -28
- data/gemfiles/embulk-latest +0 -4
- data/gemfiles/template.erb +0 -4
- data/lib/embulk/input/marketo/activity_log.rb +0 -103
- data/lib/embulk/input/marketo/base.rb +0 -139
- data/lib/embulk/input/marketo/lead.rb +0 -143
- data/lib/embulk/input/marketo_api.rb +0 -22
- data/lib/embulk/input/marketo_api/soap/activity_log.rb +0 -103
- data/lib/embulk/input/marketo_api/soap/base.rb +0 -135
- data/lib/embulk/input/marketo_api/soap/lead.rb +0 -91
- data/test/activity_log_fixtures.rb +0 -216
- data/test/embulk/input/marketo/test_activity_log.rb +0 -444
- data/test/embulk/input/marketo/test_base.rb +0 -76
- data/test/embulk/input/marketo/test_lead.rb +0 -605
- data/test/embulk/input/marketo_api/soap/test_activity_log.rb +0 -154
- data/test/embulk/input/marketo_api/soap/test_base.rb +0 -96
- data/test/embulk/input/marketo_api/soap/test_lead.rb +0 -139
- data/test/embulk/input/test_marketo_api.rb +0 -28
- data/test/lead_fixtures.rb +0 -111
- data/test/mute_logger.rb +0 -7
- data/test/override_assert_raise.rb +0 -18
- data/test/prepare_embulk.rb +0 -15
- data/test/run-test.rb +0 -26
- data/test/savon_helper.rb +0 -17
@@ -0,0 +1,220 @@
|
|
1
|
+
package org.embulk.input.marketo.rest;
|
2
|
+
|
3
|
+
import com.google.common.collect.ImmutableListMultimap;
|
4
|
+
import com.google.common.collect.Lists;
|
5
|
+
import com.google.common.collect.Maps;
|
6
|
+
import com.google.common.collect.Multimap;
|
7
|
+
import org.eclipse.jetty.client.HttpClient;
|
8
|
+
import org.eclipse.jetty.client.HttpResponseException;
|
9
|
+
import org.eclipse.jetty.client.api.ContentProvider;
|
10
|
+
import org.eclipse.jetty.client.api.Request;
|
11
|
+
import org.eclipse.jetty.client.api.Response;
|
12
|
+
import org.eclipse.jetty.client.util.StringContentProvider;
|
13
|
+
import org.eclipse.jetty.http.HttpMethod;
|
14
|
+
import org.embulk.EmbulkTestRuntime;
|
15
|
+
import org.embulk.input.marketo.exception.MarketoAPIException;
|
16
|
+
import org.embulk.input.marketo.model.MarketoError;
|
17
|
+
import org.embulk.input.marketo.model.MarketoResponse;
|
18
|
+
import org.embulk.spi.DataException;
|
19
|
+
import org.embulk.util.retryhelper.jetty92.Jetty92RetryHelper;
|
20
|
+
import org.embulk.util.retryhelper.jetty92.Jetty92SingleRequester;
|
21
|
+
import org.embulk.util.retryhelper.jetty92.StringJetty92ResponseEntityReader;
|
22
|
+
import org.junit.Before;
|
23
|
+
import org.junit.Rule;
|
24
|
+
import org.junit.Test;
|
25
|
+
import org.mockito.ArgumentCaptor;
|
26
|
+
|
27
|
+
import java.nio.charset.StandardCharsets;
|
28
|
+
import java.util.HashMap;
|
29
|
+
import java.util.Map;
|
30
|
+
|
31
|
+
import static org.junit.Assert.*;
|
32
|
+
import static org.mockito.Mockito.*;
|
33
|
+
|
34
|
+
/**
|
35
|
+
* Created by tai.khuu on 9/21/17.
|
36
|
+
*/
|
37
|
+
public class MarketoBaseRestClientTest
|
38
|
+
{
|
39
|
+
|
40
|
+
private static final String IDENTITY_END_POINT = "identityEndPoint";
|
41
|
+
|
42
|
+
private static final int MARKETO_LIMIT_INTERVAL_MILIS = 1000;
|
43
|
+
|
44
|
+
private MarketoBaseRestClient marketoBaseRestClient;
|
45
|
+
|
46
|
+
|
47
|
+
private Jetty92RetryHelper mockJetty92;
|
48
|
+
|
49
|
+
@Rule
|
50
|
+
public EmbulkTestRuntime runtime = new EmbulkTestRuntime();
|
51
|
+
@Before
|
52
|
+
public void prepare()
|
53
|
+
{
|
54
|
+
mockJetty92 = mock(Jetty92RetryHelper.class);
|
55
|
+
marketoBaseRestClient = new MarketoBaseRestClient("identityEndPoint", "clientId", "clientSecret", MARKETO_LIMIT_INTERVAL_MILIS, mockJetty92);
|
56
|
+
}
|
57
|
+
|
58
|
+
@Test
|
59
|
+
public void doGet() throws Exception
|
60
|
+
{
|
61
|
+
|
62
|
+
}
|
63
|
+
|
64
|
+
@Test
|
65
|
+
public void testGetAccessToken()
|
66
|
+
{
|
67
|
+
when(mockJetty92.requestWithRetry(any(StringJetty92ResponseEntityReader.class), any(Jetty92SingleRequester.class))).thenReturn("{\n" +
|
68
|
+
" \"access_token\": \"access_token\",\n" +
|
69
|
+
" \"token_type\": \"bearer\",\n" +
|
70
|
+
" \"expires_in\": 3599,\n" +
|
71
|
+
" \"scope\": \"tai@treasure-data.com\"\n" +
|
72
|
+
"}");
|
73
|
+
String accessToken = marketoBaseRestClient.getAccessToken();
|
74
|
+
assertEquals("access_token", accessToken);
|
75
|
+
}
|
76
|
+
|
77
|
+
@Test
|
78
|
+
public void testGetAccessTokenRequester()
|
79
|
+
{
|
80
|
+
|
81
|
+
ArgumentCaptor<Jetty92SingleRequester> jetty92SingleRequesterArgumentCaptor = ArgumentCaptor.forClass(Jetty92SingleRequester.class);
|
82
|
+
when(mockJetty92.requestWithRetry(any(StringJetty92ResponseEntityReader.class), jetty92SingleRequesterArgumentCaptor.capture())).thenReturn("{\"access_token\": \"access_token\"}");
|
83
|
+
String accessToken = marketoBaseRestClient.getAccessToken();
|
84
|
+
assertEquals("access_token", accessToken);
|
85
|
+
Jetty92SingleRequester value = jetty92SingleRequesterArgumentCaptor.getValue();
|
86
|
+
HttpClient client = mock(HttpClient.class);
|
87
|
+
Response.Listener listener = mock(Response.Listener.class);
|
88
|
+
Request mockRequest = mock(Request.class);
|
89
|
+
when(client.newRequest(eq(IDENTITY_END_POINT + MarketoRESTEndpoint.ACCESS_TOKEN.getEndpoint()))).thenReturn(mockRequest);
|
90
|
+
Request request1 = mock(Request.class);
|
91
|
+
when(mockRequest.method(eq(HttpMethod.GET))).thenReturn(request1);
|
92
|
+
value.requestOnce(client, listener);
|
93
|
+
verify(request1, times(1)).param(eq("client_id"), eq("clientId"));
|
94
|
+
verify(request1, times(1)).param(eq("client_secret"), eq("clientSecret"));
|
95
|
+
verify(request1, times(1)).param(eq("grant_type"), eq("client_credentials"));
|
96
|
+
assertTrue(value.toRetry(createHttpResponseException(502)));
|
97
|
+
}
|
98
|
+
@Test
|
99
|
+
public void testGetAccessTokenWithError()
|
100
|
+
{
|
101
|
+
ArgumentCaptor<Jetty92SingleRequester> jetty92SingleRequesterArgumentCaptor = ArgumentCaptor.forClass(Jetty92SingleRequester.class);
|
102
|
+
when(mockJetty92.requestWithRetry(any(StringJetty92ResponseEntityReader.class), jetty92SingleRequesterArgumentCaptor.capture())).thenReturn("{\n" +
|
103
|
+
" \"error\": \"invalid_client\",\n" +
|
104
|
+
" \"error_description\": \"Bad client credentials\"\n" +
|
105
|
+
"}");
|
106
|
+
try {
|
107
|
+
marketoBaseRestClient.getAccessToken();
|
108
|
+
} catch (DataException ex) {
|
109
|
+
assertEquals("Bad client credentials", ex.getMessage());
|
110
|
+
return;
|
111
|
+
}
|
112
|
+
fail();
|
113
|
+
}
|
114
|
+
|
115
|
+
@Test
|
116
|
+
public void testDoPost() throws Exception
|
117
|
+
{
|
118
|
+
MarketoBaseRestClient spy = spy(marketoBaseRestClient);
|
119
|
+
spy.doPost("target", Maps.<String, String>newHashMap(), new ImmutableListMultimap.Builder<String, String>().build(), "test_content", new StringJetty92ResponseEntityReader(10));
|
120
|
+
verify(spy, times(1)).doRequest(anyString(), eq(HttpMethod.POST), any(Map.class), any(Multimap.class), any(StringContentProvider.class), any(StringJetty92ResponseEntityReader.class));
|
121
|
+
}
|
122
|
+
|
123
|
+
@Test
|
124
|
+
public void testDoGet() throws Exception
|
125
|
+
{
|
126
|
+
MarketoBaseRestClient spy = spy(marketoBaseRestClient);
|
127
|
+
spy.doGet("target", Maps.<String, String>newHashMap(), new ImmutableListMultimap.Builder<String, String>().build(), new StringJetty92ResponseEntityReader(10));
|
128
|
+
verify(spy, times(1)).doRequest(anyString(), eq(HttpMethod.GET), any(Map.class), any(Multimap.class), isNull(ContentProvider.class), any(StringJetty92ResponseEntityReader.class));
|
129
|
+
}
|
130
|
+
|
131
|
+
@Test
|
132
|
+
public void testDoRequestRequester() throws Exception
|
133
|
+
{
|
134
|
+
MarketoBaseRestClient spy = spy(marketoBaseRestClient);
|
135
|
+
StringContentProvider contentProvider = new StringContentProvider("Content", StandardCharsets.UTF_8);
|
136
|
+
ArgumentCaptor<Jetty92SingleRequester> jetty92SingleRequesterArgumentCaptor = ArgumentCaptor.forClass(Jetty92SingleRequester.class);
|
137
|
+
|
138
|
+
MarketoResponse<Object> expectedMarketoResponse = new MarketoResponse<>();
|
139
|
+
|
140
|
+
when(mockJetty92.requestWithRetry(any(MarketoResponseJetty92EntityReader.class), jetty92SingleRequesterArgumentCaptor.capture())).thenReturn(expectedMarketoResponse);
|
141
|
+
when(mockJetty92.requestWithRetry(any(StringJetty92ResponseEntityReader.class), any(Jetty92SingleRequester.class))).thenReturn("{\"access_token\": \"access_token\"}");
|
142
|
+
|
143
|
+
String target = "target";
|
144
|
+
HashMap<String, String> headers = Maps.<String, String>newHashMap();
|
145
|
+
headers.put("testHeader1", "testHeaderValue1");
|
146
|
+
|
147
|
+
ImmutableListMultimap<String, String> build = new ImmutableListMultimap.Builder<String, String>().put("param", "param1").build();
|
148
|
+
|
149
|
+
MarketoResponse<Object> marketoResponse = spy.doRequest(target, HttpMethod.POST, headers, build, contentProvider, new MarketoResponseJetty92EntityReader<Object>(10));
|
150
|
+
|
151
|
+
HttpClient client = mock(HttpClient.class);
|
152
|
+
Response.Listener listener = mock(Response.Listener.class);
|
153
|
+
Request mockRequest = mock(Request.class);
|
154
|
+
when(client.newRequest(eq(target))).thenReturn(mockRequest);
|
155
|
+
|
156
|
+
when(mockRequest.method(eq(HttpMethod.POST))).thenReturn(mockRequest);
|
157
|
+
Jetty92SingleRequester jetty92SingleRequester = jetty92SingleRequesterArgumentCaptor.getValue();
|
158
|
+
jetty92SingleRequester.requestOnce(client, listener);
|
159
|
+
|
160
|
+
assertEquals(expectedMarketoResponse, marketoResponse);
|
161
|
+
|
162
|
+
verify(mockRequest, times(1)).header(eq("testHeader1"), eq("testHeaderValue1"));
|
163
|
+
verify(mockRequest, times(1)).header(eq("Authorization"), eq("Bearer access_token"));
|
164
|
+
verify(mockRequest, times(1)).param(eq("param"), eq("param1"));
|
165
|
+
verify(mockRequest, times(1)).content(eq(contentProvider), eq("application/json"));
|
166
|
+
|
167
|
+
}
|
168
|
+
|
169
|
+
@Test
|
170
|
+
public void testDoRequesterRetry() throws Exception
|
171
|
+
{
|
172
|
+
MarketoBaseRestClient spy = spy(marketoBaseRestClient);
|
173
|
+
ArgumentCaptor<Jetty92SingleRequester> jetty92SingleRequesterArgumentCaptor = ArgumentCaptor.forClass(Jetty92SingleRequester.class);
|
174
|
+
|
175
|
+
when(mockJetty92.requestWithRetry(any(MarketoResponseJetty92EntityReader.class), jetty92SingleRequesterArgumentCaptor.capture())).thenReturn(new MarketoResponse<>());
|
176
|
+
when(mockJetty92.requestWithRetry(any(StringJetty92ResponseEntityReader.class), any(Jetty92SingleRequester.class))).thenReturn("{\"access_token\": \"access_token\"}");
|
177
|
+
|
178
|
+
spy.doRequest("", HttpMethod.POST, null, null, null, new MarketoResponseJetty92EntityReader<Object>(10));
|
179
|
+
|
180
|
+
HttpClient client = mock(HttpClient.class);
|
181
|
+
Response.Listener listener = mock(Response.Listener.class);
|
182
|
+
Request mockRequest = mock(Request.class);
|
183
|
+
when(client.newRequest(anyString())).thenReturn(mockRequest);
|
184
|
+
|
185
|
+
when(mockRequest.method(eq(HttpMethod.POST))).thenReturn(mockRequest);
|
186
|
+
|
187
|
+
Jetty92SingleRequester jetty92SingleRequester = jetty92SingleRequesterArgumentCaptor.getValue();
|
188
|
+
jetty92SingleRequester.requestOnce(client, listener);
|
189
|
+
assertTrue(jetty92SingleRequester.toRetry(createHttpResponseException(502)));
|
190
|
+
|
191
|
+
|
192
|
+
assertFalse(jetty92SingleRequester.toRetry(createHttpResponseException(400)));
|
193
|
+
|
194
|
+
assertFalse(jetty92SingleRequester.toRetry(createMarketoAPIException("ERR", "ERR")));
|
195
|
+
assertTrue(jetty92SingleRequester.toRetry(createMarketoAPIException("606", "")));
|
196
|
+
assertTrue(jetty92SingleRequester.toRetry(createMarketoAPIException("615", "")));
|
197
|
+
assertTrue(jetty92SingleRequester.toRetry(createMarketoAPIException("602", "")));
|
198
|
+
|
199
|
+
verify(mockJetty92, times(2)).requestWithRetry(any(StringJetty92ResponseEntityReader.class), any(Jetty92SingleRequester.class));
|
200
|
+
|
201
|
+
}
|
202
|
+
|
203
|
+
private HttpResponseException createHttpResponseException(int statusCode)
|
204
|
+
{
|
205
|
+
HttpResponseException exception = mock(HttpResponseException.class);
|
206
|
+
Response response = mock(Response.class);
|
207
|
+
when(exception.getResponse()).thenReturn(response);
|
208
|
+
when(response.getStatus()).thenReturn(statusCode);
|
209
|
+
return exception;
|
210
|
+
}
|
211
|
+
|
212
|
+
private MarketoAPIException createMarketoAPIException(String code, String error)
|
213
|
+
{
|
214
|
+
MarketoError marketoError = new MarketoError();
|
215
|
+
marketoError.setCode(code);
|
216
|
+
marketoError.setMessage(error);
|
217
|
+
return new MarketoAPIException(Lists.newArrayList(marketoError));
|
218
|
+
}
|
219
|
+
|
220
|
+
}
|
metadata
CHANGED
@@ -1,96 +1,19 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: embulk-input-marketo
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.5.
|
4
|
+
version: 0.5.7.alpha.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
|
-
-
|
8
|
-
- yoshihara
|
7
|
+
- Tai Khuu
|
9
8
|
autorequire:
|
10
9
|
bindir: bin
|
11
10
|
cert_chain: []
|
12
|
-
date:
|
11
|
+
date: 2017-09-22 00:00:00.000000000 Z
|
13
12
|
dependencies:
|
14
13
|
- !ruby/object:Gem::Dependency
|
15
14
|
requirement: !ruby/object:Gem::Requirement
|
16
15
|
requirements:
|
17
|
-
- -
|
18
|
-
- !ruby/object:Gem::Version
|
19
|
-
version: 2.11.1
|
20
|
-
name: savon
|
21
|
-
prerelease: false
|
22
|
-
type: :runtime
|
23
|
-
version_requirements: !ruby/object:Gem::Requirement
|
24
|
-
requirements:
|
25
|
-
- - "~>"
|
26
|
-
- !ruby/object:Gem::Version
|
27
|
-
version: 2.11.1
|
28
|
-
- !ruby/object:Gem::Dependency
|
29
|
-
requirement: !ruby/object:Gem::Requirement
|
30
|
-
requirements:
|
31
|
-
- - ">="
|
32
|
-
- !ruby/object:Gem::Version
|
33
|
-
version: 2.8.3
|
34
|
-
name: httpclient
|
35
|
-
prerelease: false
|
36
|
-
type: :runtime
|
37
|
-
version_requirements: !ruby/object:Gem::Requirement
|
38
|
-
requirements:
|
39
|
-
- - ">="
|
40
|
-
- !ruby/object:Gem::Version
|
41
|
-
version: 2.8.3
|
42
|
-
- !ruby/object:Gem::Dependency
|
43
|
-
requirement: !ruby/object:Gem::Requirement
|
44
|
-
requirements:
|
45
|
-
- - '='
|
46
|
-
- !ruby/object:Gem::Version
|
47
|
-
version: 2.4.2
|
48
|
-
name: httpi
|
49
|
-
prerelease: false
|
50
|
-
type: :runtime
|
51
|
-
version_requirements: !ruby/object:Gem::Requirement
|
52
|
-
requirements:
|
53
|
-
- - '='
|
54
|
-
- !ruby/object:Gem::Version
|
55
|
-
version: 2.4.2
|
56
|
-
- !ruby/object:Gem::Dependency
|
57
|
-
requirement: !ruby/object:Gem::Requirement
|
58
|
-
requirements:
|
59
|
-
- - "~>"
|
60
|
-
- !ruby/object:Gem::Version
|
61
|
-
version: '0.5'
|
62
|
-
name: perfect_retry
|
63
|
-
prerelease: false
|
64
|
-
type: :runtime
|
65
|
-
version_requirements: !ruby/object:Gem::Requirement
|
66
|
-
requirements:
|
67
|
-
- - "~>"
|
68
|
-
- !ruby/object:Gem::Version
|
69
|
-
version: '0.5'
|
70
|
-
- !ruby/object:Gem::Dependency
|
71
|
-
requirement: !ruby/object:Gem::Requirement
|
72
|
-
requirements:
|
73
|
-
- - ">="
|
74
|
-
- !ruby/object:Gem::Version
|
75
|
-
version: 0.6.13
|
76
|
-
- - "<"
|
77
|
-
- !ruby/object:Gem::Version
|
78
|
-
version: '1.0'
|
79
|
-
name: embulk
|
80
|
-
prerelease: false
|
81
|
-
type: :development
|
82
|
-
version_requirements: !ruby/object:Gem::Requirement
|
83
|
-
requirements:
|
84
|
-
- - ">="
|
85
|
-
- !ruby/object:Gem::Version
|
86
|
-
version: 0.6.13
|
87
|
-
- - "<"
|
88
|
-
- !ruby/object:Gem::Version
|
89
|
-
version: '1.0'
|
90
|
-
- !ruby/object:Gem::Dependency
|
91
|
-
requirement: !ruby/object:Gem::Requirement
|
92
|
-
requirements:
|
93
|
-
- - "~>"
|
16
|
+
- - ~>
|
94
17
|
- !ruby/object:Gem::Version
|
95
18
|
version: '1.0'
|
96
19
|
name: bundler
|
@@ -98,13 +21,13 @@ dependencies:
|
|
98
21
|
type: :development
|
99
22
|
version_requirements: !ruby/object:Gem::Requirement
|
100
23
|
requirements:
|
101
|
-
- -
|
24
|
+
- - ~>
|
102
25
|
- !ruby/object:Gem::Version
|
103
26
|
version: '1.0'
|
104
27
|
- !ruby/object:Gem::Dependency
|
105
28
|
requirement: !ruby/object:Gem::Requirement
|
106
29
|
requirements:
|
107
|
-
- -
|
30
|
+
- - '>='
|
108
31
|
- !ruby/object:Gem::Version
|
109
32
|
version: '10.0'
|
110
33
|
name: rake
|
@@ -112,137 +35,71 @@ dependencies:
|
|
112
35
|
type: :development
|
113
36
|
version_requirements: !ruby/object:Gem::Requirement
|
114
37
|
requirements:
|
115
|
-
- -
|
38
|
+
- - '>='
|
116
39
|
- !ruby/object:Gem::Version
|
117
40
|
version: '10.0'
|
118
|
-
- !ruby/object:Gem::Dependency
|
119
|
-
requirement: !ruby/object:Gem::Requirement
|
120
|
-
requirements:
|
121
|
-
- - ">="
|
122
|
-
- !ruby/object:Gem::Version
|
123
|
-
version: '0'
|
124
|
-
name: pry
|
125
|
-
prerelease: false
|
126
|
-
type: :development
|
127
|
-
version_requirements: !ruby/object:Gem::Requirement
|
128
|
-
requirements:
|
129
|
-
- - ">="
|
130
|
-
- !ruby/object:Gem::Version
|
131
|
-
version: '0'
|
132
|
-
- !ruby/object:Gem::Dependency
|
133
|
-
requirement: !ruby/object:Gem::Requirement
|
134
|
-
requirements:
|
135
|
-
- - ">="
|
136
|
-
- !ruby/object:Gem::Version
|
137
|
-
version: '0'
|
138
|
-
name: test-unit
|
139
|
-
prerelease: false
|
140
|
-
type: :development
|
141
|
-
version_requirements: !ruby/object:Gem::Requirement
|
142
|
-
requirements:
|
143
|
-
- - ">="
|
144
|
-
- !ruby/object:Gem::Version
|
145
|
-
version: '0'
|
146
|
-
- !ruby/object:Gem::Dependency
|
147
|
-
requirement: !ruby/object:Gem::Requirement
|
148
|
-
requirements:
|
149
|
-
- - '='
|
150
|
-
- !ruby/object:Gem::Version
|
151
|
-
version: 1.1.2
|
152
|
-
name: rr
|
153
|
-
prerelease: false
|
154
|
-
type: :development
|
155
|
-
version_requirements: !ruby/object:Gem::Requirement
|
156
|
-
requirements:
|
157
|
-
- - '='
|
158
|
-
- !ruby/object:Gem::Version
|
159
|
-
version: 1.1.2
|
160
|
-
- !ruby/object:Gem::Dependency
|
161
|
-
requirement: !ruby/object:Gem::Requirement
|
162
|
-
requirements:
|
163
|
-
- - ">="
|
164
|
-
- !ruby/object:Gem::Version
|
165
|
-
version: '0'
|
166
|
-
name: test-unit-rr
|
167
|
-
prerelease: false
|
168
|
-
type: :development
|
169
|
-
version_requirements: !ruby/object:Gem::Requirement
|
170
|
-
requirements:
|
171
|
-
- - ">="
|
172
|
-
- !ruby/object:Gem::Version
|
173
|
-
version: '0'
|
174
|
-
- !ruby/object:Gem::Dependency
|
175
|
-
requirement: !ruby/object:Gem::Requirement
|
176
|
-
requirements:
|
177
|
-
- - "~>"
|
178
|
-
- !ruby/object:Gem::Version
|
179
|
-
version: '0.5'
|
180
|
-
name: codeclimate-test-reporter
|
181
|
-
prerelease: false
|
182
|
-
type: :development
|
183
|
-
version_requirements: !ruby/object:Gem::Requirement
|
184
|
-
requirements:
|
185
|
-
- - "~>"
|
186
|
-
- !ruby/object:Gem::Version
|
187
|
-
version: '0.5'
|
188
|
-
- !ruby/object:Gem::Dependency
|
189
|
-
requirement: !ruby/object:Gem::Requirement
|
190
|
-
requirements:
|
191
|
-
- - ">="
|
192
|
-
- !ruby/object:Gem::Version
|
193
|
-
version: '0'
|
194
|
-
name: everyleaf-embulk_helper
|
195
|
-
prerelease: false
|
196
|
-
type: :development
|
197
|
-
version_requirements: !ruby/object:Gem::Requirement
|
198
|
-
requirements:
|
199
|
-
- - ">="
|
200
|
-
- !ruby/object:Gem::Version
|
201
|
-
version: '0'
|
202
41
|
description: Loads records from Marketo.
|
203
42
|
email:
|
204
|
-
-
|
205
|
-
- h.yoshihara@everyleaf.com
|
43
|
+
- tai@treasuredata.com
|
206
44
|
executables: []
|
207
45
|
extensions: []
|
208
46
|
extra_rdoc_files: []
|
209
47
|
files:
|
210
|
-
-
|
211
|
-
-
|
212
|
-
-
|
213
|
-
- ".travis.yml.erb"
|
48
|
+
- .github/PULL_REQUEST_TEMPLATE.md
|
49
|
+
- .gitignore
|
50
|
+
- .travis.yml
|
214
51
|
- CHANGELOG.md
|
215
|
-
-
|
216
|
-
- LICENSE
|
52
|
+
- LICENSE.txt
|
217
53
|
- README.md
|
218
|
-
-
|
219
|
-
-
|
220
|
-
-
|
221
|
-
-
|
222
|
-
-
|
223
|
-
-
|
224
|
-
-
|
225
|
-
- lib/embulk/input/
|
226
|
-
-
|
227
|
-
-
|
228
|
-
-
|
229
|
-
-
|
230
|
-
-
|
231
|
-
-
|
232
|
-
-
|
233
|
-
-
|
234
|
-
-
|
235
|
-
-
|
236
|
-
-
|
237
|
-
-
|
238
|
-
-
|
239
|
-
-
|
240
|
-
-
|
241
|
-
-
|
242
|
-
-
|
243
|
-
|
54
|
+
- build.gradle
|
55
|
+
- config/checkstyle/checkstyle.xml
|
56
|
+
- config/checkstyle/default.xml
|
57
|
+
- gradle/wrapper/gradle-wrapper.jar
|
58
|
+
- gradle/wrapper/gradle-wrapper.properties
|
59
|
+
- gradlew
|
60
|
+
- gradlew.bat
|
61
|
+
- lib/embulk/input/marketo.rb
|
62
|
+
- settings.gradle
|
63
|
+
- src/main/java/org/embulk/input/marketo/CsvTokenizer.java
|
64
|
+
- src/main/java/org/embulk/input/marketo/MarketoInputPlugin.java
|
65
|
+
- src/main/java/org/embulk/input/marketo/MarketoInputPluginDelegate.java
|
66
|
+
- src/main/java/org/embulk/input/marketo/MarketoService.java
|
67
|
+
- src/main/java/org/embulk/input/marketo/MarketoServiceImpl.java
|
68
|
+
- src/main/java/org/embulk/input/marketo/MarketoUtils.java
|
69
|
+
- src/main/java/org/embulk/input/marketo/delegate/ActivityBulkExtractInputPlugin.java
|
70
|
+
- src/main/java/org/embulk/input/marketo/delegate/CampaignInputPlugin.java
|
71
|
+
- src/main/java/org/embulk/input/marketo/delegate/LeadBulkExtractInputPlugin.java
|
72
|
+
- src/main/java/org/embulk/input/marketo/delegate/LeadWithListInputPlugin.java
|
73
|
+
- src/main/java/org/embulk/input/marketo/delegate/LeadWithProgramInputPlugin.java
|
74
|
+
- src/main/java/org/embulk/input/marketo/delegate/MarketoBaseBulkExtractInputPlugin.java
|
75
|
+
- src/main/java/org/embulk/input/marketo/delegate/MarketoBaseInputPluginDelegate.java
|
76
|
+
- src/main/java/org/embulk/input/marketo/exception/MarketoAPIException.java
|
77
|
+
- src/main/java/org/embulk/input/marketo/model/MarketoAccessTokenResponse.java
|
78
|
+
- src/main/java/org/embulk/input/marketo/model/MarketoBulkExtractRequest.java
|
79
|
+
- src/main/java/org/embulk/input/marketo/model/MarketoError.java
|
80
|
+
- src/main/java/org/embulk/input/marketo/model/MarketoField.java
|
81
|
+
- src/main/java/org/embulk/input/marketo/model/MarketoResponse.java
|
82
|
+
- src/main/java/org/embulk/input/marketo/model/filter/DateRangeFilter.java
|
83
|
+
- src/main/java/org/embulk/input/marketo/model/filter/ListFilter.java
|
84
|
+
- src/main/java/org/embulk/input/marketo/model/filter/MarketoFilter.java
|
85
|
+
- src/main/java/org/embulk/input/marketo/rest/MarketoBaseRestClient.java
|
86
|
+
- src/main/java/org/embulk/input/marketo/rest/MarketoFileResponseEntityReader.java
|
87
|
+
- src/main/java/org/embulk/input/marketo/rest/MarketoRESTEndpoint.java
|
88
|
+
- src/main/java/org/embulk/input/marketo/rest/MarketoResponseJetty92EntityReader.java
|
89
|
+
- src/main/java/org/embulk/input/marketo/rest/MarketoRestClient.java
|
90
|
+
- src/main/java/org/embulk/input/marketo/rest/RecordPagingIterable.java
|
91
|
+
- src/test/java/org/embulk/input/marketo/TestMarketoInputPlugin.java
|
92
|
+
- src/test/java/org/embulk/input/marketo/rest/MarketoBaseRestClientTest.java
|
93
|
+
- classpath/jetty-http-9.2.14.v20151106.jar
|
94
|
+
- classpath/embulk-base-restclient-0.5.3.jar
|
95
|
+
- classpath/jetty-client-9.2.14.v20151106.jar
|
96
|
+
- classpath/embulk-input-marketo-0.5.7.alpha.1.jar
|
97
|
+
- classpath/jetty-util-9.2.14.v20151106.jar
|
98
|
+
- classpath/embulk-util-retryhelper-jetty92-0.5.3.jar
|
99
|
+
- classpath/jetty-io-9.2.14.v20151106.jar
|
100
|
+
homepage:
|
244
101
|
licenses:
|
245
|
-
-
|
102
|
+
- MIT
|
246
103
|
metadata: {}
|
247
104
|
post_install_message:
|
248
105
|
rdoc_options: []
|
@@ -250,32 +107,18 @@ require_paths:
|
|
250
107
|
- lib
|
251
108
|
required_ruby_version: !ruby/object:Gem::Requirement
|
252
109
|
requirements:
|
253
|
-
- -
|
110
|
+
- - '>='
|
254
111
|
- !ruby/object:Gem::Version
|
255
112
|
version: '0'
|
256
113
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
257
114
|
requirements:
|
258
|
-
- -
|
115
|
+
- - '>'
|
259
116
|
- !ruby/object:Gem::Version
|
260
|
-
version:
|
117
|
+
version: 1.3.1
|
261
118
|
requirements: []
|
262
119
|
rubyforge_project:
|
263
|
-
rubygems_version: 2.
|
120
|
+
rubygems_version: 2.1.9
|
264
121
|
signing_key:
|
265
122
|
specification_version: 4
|
266
123
|
summary: Marketo input plugin for Embulk
|
267
|
-
test_files:
|
268
|
-
- test/activity_log_fixtures.rb
|
269
|
-
- test/embulk/input/marketo/test_activity_log.rb
|
270
|
-
- test/embulk/input/marketo/test_base.rb
|
271
|
-
- test/embulk/input/marketo/test_lead.rb
|
272
|
-
- test/embulk/input/marketo_api/soap/test_activity_log.rb
|
273
|
-
- test/embulk/input/marketo_api/soap/test_base.rb
|
274
|
-
- test/embulk/input/marketo_api/soap/test_lead.rb
|
275
|
-
- test/embulk/input/test_marketo_api.rb
|
276
|
-
- test/lead_fixtures.rb
|
277
|
-
- test/mute_logger.rb
|
278
|
-
- test/override_assert_raise.rb
|
279
|
-
- test/prepare_embulk.rb
|
280
|
-
- test/run-test.rb
|
281
|
-
- test/savon_helper.rb
|
124
|
+
test_files: []
|