simplyrets 2.0.0 → 2.0.1
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 +4 -4
- data/Gemfile.lock +6 -3
- data/Makefile +1 -2
- data/README.org +2 -0
- data/lib/simplyrets.rb +12 -1
- data/lib/simplyrets/api/default_api.rb +132 -128
- data/lib/simplyrets/api_client.rb +48 -9
- data/lib/simplyrets/api_client.rb.orig +373 -0
- data/lib/simplyrets/api_error.rb +12 -1
- data/lib/simplyrets/configuration.rb +23 -0
- data/lib/simplyrets/models/agent.rb +61 -27
- data/lib/simplyrets/models/broker.rb +57 -20
- data/lib/simplyrets/models/contact_information.rb +62 -27
- data/lib/simplyrets/models/error.rb +59 -23
- data/lib/simplyrets/models/geographic_data.rb +61 -28
- data/lib/simplyrets/models/listing.rb +94 -70
- data/lib/simplyrets/models/mls_information.rb +95 -37
- data/lib/simplyrets/models/office.rb +62 -28
- data/lib/simplyrets/models/open_house.rb +66 -36
- data/lib/simplyrets/models/parking.rb +59 -24
- data/lib/simplyrets/models/property.rb +128 -136
- data/lib/simplyrets/models/sales.rb +61 -28
- data/lib/simplyrets/models/school.rb +60 -34
- data/lib/simplyrets/models/street_address.rb +66 -55
- data/lib/simplyrets/models/tax.rb +70 -35
- data/lib/simplyrets/version.rb +13 -2
- data/ruby-client.meta +1 -0
- data/ruby-client.zip +0 -0
- data/ruby-client/.gitignore +50 -0
- data/ruby-client/.rspec +2 -0
- data/ruby-client/.swagger-codegen-ignore +23 -0
- data/ruby-client/LICENSE +201 -0
- data/ruby-client/README.md +128 -0
- data/ruby-client/docs/Agent.md +11 -0
- data/ruby-client/docs/Broker.md +8 -0
- data/ruby-client/docs/ContactInformation.md +10 -0
- data/ruby-client/docs/DefaultApi.md +306 -0
- data/ruby-client/docs/Error.md +9 -0
- data/ruby-client/docs/GeographicData.md +12 -0
- data/ruby-client/docs/Listing.md +30 -0
- data/ruby-client/docs/MlsInformation.md +11 -0
- data/ruby-client/docs/Office.md +11 -0
- data/ruby-client/docs/OpenHouse.md +15 -0
- data/ruby-client/docs/Parking.md +10 -0
- data/ruby-client/docs/Property.md +43 -0
- data/ruby-client/docs/Sales.md +12 -0
- data/ruby-client/docs/School.md +11 -0
- data/ruby-client/docs/StreetAddress.md +16 -0
- data/ruby-client/docs/Tax.md +10 -0
- data/ruby-client/git_push.sh +67 -0
- data/ruby-client/lib/swagger_client.rb +66 -0
- data/ruby-client/lib/swagger_client/api/default_api.rb +383 -0
- data/ruby-client/lib/swagger_client/api_client.rb +373 -0
- data/ruby-client/lib/swagger_client/api_error.rb +47 -0
- data/ruby-client/lib/swagger_client/configuration.rb +193 -0
- data/ruby-client/lib/swagger_client/models/agent.rb +230 -0
- data/ruby-client/lib/swagger_client/models/broker.rb +200 -0
- data/ruby-client/lib/swagger_client/models/contact_information.rb +220 -0
- data/ruby-client/lib/swagger_client/models/error.rb +210 -0
- data/ruby-client/lib/swagger_client/models/geographic_data.rb +240 -0
- data/ruby-client/lib/swagger_client/models/listing.rb +422 -0
- data/ruby-client/lib/swagger_client/models/mls_information.rb +263 -0
- data/ruby-client/lib/swagger_client/models/office.rb +230 -0
- data/ruby-client/lib/swagger_client/models/open_house.rb +270 -0
- data/ruby-client/lib/swagger_client/models/parking.rb +219 -0
- data/ruby-client/lib/swagger_client/models/property.rb +574 -0
- data/ruby-client/lib/swagger_client/models/sales.rb +240 -0
- data/ruby-client/lib/swagger_client/models/school.rb +230 -0
- data/ruby-client/lib/swagger_client/models/street_address.rb +280 -0
- data/ruby-client/lib/swagger_client/models/tax.rb +220 -0
- data/ruby-client/lib/swagger_client/version.rb +26 -0
- data/ruby-client/spec/api/default_api_spec.rb +132 -0
- data/ruby-client/spec/api_client_spec.rb +296 -0
- data/ruby-client/spec/configuration_spec.rb +48 -0
- data/ruby-client/spec/models/agent_spec.rb +71 -0
- data/ruby-client/spec/models/broker_spec.rb +53 -0
- data/ruby-client/spec/models/contact_information_spec.rb +65 -0
- data/ruby-client/spec/models/error_spec.rb +59 -0
- data/ruby-client/spec/models/geographic_data_spec.rb +77 -0
- data/ruby-client/spec/models/listing_spec.rb +185 -0
- data/ruby-client/spec/models/mls_information_spec.rb +74 -0
- data/ruby-client/spec/models/office_spec.rb +71 -0
- data/ruby-client/spec/models/open_house_spec.rb +95 -0
- data/ruby-client/spec/models/parking_spec.rb +65 -0
- data/ruby-client/spec/models/property_spec.rb +266 -0
- data/ruby-client/spec/models/sales_spec.rb +77 -0
- data/ruby-client/spec/models/school_spec.rb +71 -0
- data/ruby-client/spec/models/street_address_spec.rb +101 -0
- data/ruby-client/spec/models/tax_spec.rb +65 -0
- data/ruby-client/spec/spec_helper.rb +122 -0
- data/ruby-client/swagger_client.gemspec +55 -0
- data/simplyrets.gemspec +1 -1
- metadata +71 -5
data/lib/simplyrets/api_error.rb
CHANGED
|
@@ -1,12 +1,23 @@
|
|
|
1
1
|
=begin
|
|
2
2
|
SimplyRETS API
|
|
3
3
|
|
|
4
|
-
The SimplyRETS API is an exciting step towards making it easier for
|
|
4
|
+
The SimplyRETS API is an exciting step towards making it easier for developers and real estate agents to build something awesome with real estate data! The documentation below makes live requests to our API using the trial data. To get set up with the API using live MLS data, you must have RETS credentials from your MLS, which you can then use to create an app with SimplyRETS. For more information on that process, please see our [FAQ](https://simplyrets.com/faq), [Getting Started](https://simplyrets.com/blog/getting-set-up.html) page, or [contact us](https://simplyrets.com/\\#home-contact). Below you'll find the API endpoints, query parameters, response bodies, and other information about using the SimplyRETS API. You can run queries by clicking the 'Try it Out' button at the bottom of each section. ### Authentication The SimplyRETS API uses Basic Authentication. When you create an app, you'll get a set of API credentials to access your listings. If you're trying out the test data, you can use `simplyrets:simplyrets` for connecting to the API. ### Media Types The SimplyRETS API uses the `Accept` header to allow clients to control media types (content versions). We maintain backwards compatibility with API clients by allowing them to specify a content version. We highly recommend setting and explicity media type when your application reaches production. Both the structure and content of our API response bodies is subject to change so we can add new features while respecting the stability of applications which have already been developed. To always use the latest SimplyRETS content version, simply use `application/json` in your application `Accept` header. If you want to pin your clients media type to a specific version, you can use the vendor-specific SimplyRETS media type, e.g. `application/vnd.simplyrets-v0.1+json\"` To view all valid content-types for making an `OPTIONS`, make a request to the SimplyRETS api root `curl -XOPTIONS -u simplyrets:simplyrets https://api.simplyrets.com/` The default media types used in our API responses may change in the future. If you're building an application and care about the stability of the API, be sure to request a specific media type in the Accept header as shown in the examples below. The wordpress plugin automatically sets the `Accept` header for the compatible SimplyRETS media types. ### Pagination There a few pieces of useful information about each request stored in the HTTP Headers: - `X-Total-Count` shows you the total amount of listings that match your current query. - `Link` contains pre-built pagination links for accessing the next 'page' of listings that match your query. Read more about that [here](https://simplyrets.com/blog/api-pagination.html).
|
|
5
5
|
|
|
6
6
|
OpenAPI spec version: 1.0.0
|
|
7
7
|
|
|
8
8
|
Generated by: https://github.com/swagger-api/swagger-codegen.git
|
|
9
9
|
|
|
10
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
you may not use this file except in compliance with the License.
|
|
12
|
+
You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
See the License for the specific language governing permissions and
|
|
20
|
+
limitations under the License.
|
|
10
21
|
|
|
11
22
|
=end
|
|
12
23
|
|
|
@@ -1,3 +1,26 @@
|
|
|
1
|
+
=begin
|
|
2
|
+
SimplyRETS API
|
|
3
|
+
|
|
4
|
+
The SimplyRETS API is an exciting step towards making it easier for developers and real estate agents to build something awesome with real estate data! The documentation below makes live requests to our API using the trial data. To get set up with the API using live MLS data, you must have RETS credentials from your MLS, which you can then use to create an app with SimplyRETS. For more information on that process, please see our [FAQ](https://simplyrets.com/faq), [Getting Started](https://simplyrets.com/blog/getting-set-up.html) page, or [contact us](https://simplyrets.com/\\#home-contact). Below you'll find the API endpoints, query parameters, response bodies, and other information about using the SimplyRETS API. You can run queries by clicking the 'Try it Out' button at the bottom of each section. ### Authentication The SimplyRETS API uses Basic Authentication. When you create an app, you'll get a set of API credentials to access your listings. If you're trying out the test data, you can use `simplyrets:simplyrets` for connecting to the API. ### Media Types The SimplyRETS API uses the `Accept` header to allow clients to control media types (content versions). We maintain backwards compatibility with API clients by allowing them to specify a content version. We highly recommend setting and explicity media type when your application reaches production. Both the structure and content of our API response bodies is subject to change so we can add new features while respecting the stability of applications which have already been developed. To always use the latest SimplyRETS content version, simply use `application/json` in your application `Accept` header. If you want to pin your clients media type to a specific version, you can use the vendor-specific SimplyRETS media type, e.g. `application/vnd.simplyrets-v0.1+json\"` To view all valid content-types for making an `OPTIONS`, make a request to the SimplyRETS api root `curl -XOPTIONS -u simplyrets:simplyrets https://api.simplyrets.com/` The default media types used in our API responses may change in the future. If you're building an application and care about the stability of the API, be sure to request a specific media type in the Accept header as shown in the examples below. The wordpress plugin automatically sets the `Accept` header for the compatible SimplyRETS media types. ### Pagination There a few pieces of useful information about each request stored in the HTTP Headers: - `X-Total-Count` shows you the total amount of listings that match your current query. - `Link` contains pre-built pagination links for accessing the next 'page' of listings that match your query. Read more about that [here](https://simplyrets.com/blog/api-pagination.html).
|
|
5
|
+
|
|
6
|
+
OpenAPI spec version: 1.0.0
|
|
7
|
+
|
|
8
|
+
Generated by: https://github.com/swagger-api/swagger-codegen.git
|
|
9
|
+
|
|
10
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
you may not use this file except in compliance with the License.
|
|
12
|
+
You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
See the License for the specific language governing permissions and
|
|
20
|
+
limitations under the License.
|
|
21
|
+
|
|
22
|
+
=end
|
|
23
|
+
|
|
1
24
|
require 'uri'
|
|
2
25
|
|
|
3
26
|
module SimplyRetsClient
|
|
@@ -1,12 +1,23 @@
|
|
|
1
1
|
=begin
|
|
2
2
|
SimplyRETS API
|
|
3
3
|
|
|
4
|
-
The SimplyRETS API is an exciting step towards making it easier for
|
|
4
|
+
The SimplyRETS API is an exciting step towards making it easier for developers and real estate agents to build something awesome with real estate data! The documentation below makes live requests to our API using the trial data. To get set up with the API using live MLS data, you must have RETS credentials from your MLS, which you can then use to create an app with SimplyRETS. For more information on that process, please see our [FAQ](https://simplyrets.com/faq), [Getting Started](https://simplyrets.com/blog/getting-set-up.html) page, or [contact us](https://simplyrets.com/\\#home-contact). Below you'll find the API endpoints, query parameters, response bodies, and other information about using the SimplyRETS API. You can run queries by clicking the 'Try it Out' button at the bottom of each section. ### Authentication The SimplyRETS API uses Basic Authentication. When you create an app, you'll get a set of API credentials to access your listings. If you're trying out the test data, you can use `simplyrets:simplyrets` for connecting to the API. ### Media Types The SimplyRETS API uses the `Accept` header to allow clients to control media types (content versions). We maintain backwards compatibility with API clients by allowing them to specify a content version. We highly recommend setting and explicity media type when your application reaches production. Both the structure and content of our API response bodies is subject to change so we can add new features while respecting the stability of applications which have already been developed. To always use the latest SimplyRETS content version, simply use `application/json` in your application `Accept` header. If you want to pin your clients media type to a specific version, you can use the vendor-specific SimplyRETS media type, e.g. `application/vnd.simplyrets-v0.1+json\"` To view all valid content-types for making an `OPTIONS`, make a request to the SimplyRETS api root `curl -XOPTIONS -u simplyrets:simplyrets https://api.simplyrets.com/` The default media types used in our API responses may change in the future. If you're building an application and care about the stability of the API, be sure to request a specific media type in the Accept header as shown in the examples below. The wordpress plugin automatically sets the `Accept` header for the compatible SimplyRETS media types. ### Pagination There a few pieces of useful information about each request stored in the HTTP Headers: - `X-Total-Count` shows you the total amount of listings that match your current query. - `Link` contains pre-built pagination links for accessing the next 'page' of listings that match your query. Read more about that [here](https://simplyrets.com/blog/api-pagination.html).
|
|
5
5
|
|
|
6
6
|
OpenAPI spec version: 1.0.0
|
|
7
7
|
|
|
8
8
|
Generated by: https://github.com/swagger-api/swagger-codegen.git
|
|
9
9
|
|
|
10
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
you may not use this file except in compliance with the License.
|
|
12
|
+
You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
See the License for the specific language governing permissions and
|
|
20
|
+
limitations under the License.
|
|
10
21
|
|
|
11
22
|
=end
|
|
12
23
|
|
|
@@ -18,7 +29,7 @@ module SimplyRetsClient
|
|
|
18
29
|
# Agent last name
|
|
19
30
|
attr_accessor :last_name
|
|
20
31
|
|
|
21
|
-
# Agent contact info. This information is only present when
|
|
32
|
+
# Agent contact info. This information is only present when your RETS feed specifies the agent wishes to show their contact information publicly. *Contact information is not available for all RETS Vendors.*
|
|
22
33
|
attr_accessor :contact
|
|
23
34
|
|
|
24
35
|
# Agent first name
|
|
@@ -27,18 +38,14 @@ module SimplyRetsClient
|
|
|
27
38
|
# Well known Agent MLS number or id.
|
|
28
39
|
attr_accessor :id
|
|
29
40
|
|
|
41
|
+
|
|
30
42
|
# Attribute mapping from ruby-style variable name to JSON key.
|
|
31
43
|
def self.attribute_map
|
|
32
44
|
{
|
|
33
|
-
|
|
34
45
|
:'last_name' => :'lastName',
|
|
35
|
-
|
|
36
46
|
:'contact' => :'contact',
|
|
37
|
-
|
|
38
47
|
:'first_name' => :'firstName',
|
|
39
|
-
|
|
40
48
|
:'id' => :'id'
|
|
41
|
-
|
|
42
49
|
}
|
|
43
50
|
end
|
|
44
51
|
|
|
@@ -49,36 +56,50 @@ module SimplyRetsClient
|
|
|
49
56
|
:'contact' => :'ContactInformation',
|
|
50
57
|
:'first_name' => :'String',
|
|
51
58
|
:'id' => :'String'
|
|
52
|
-
|
|
53
59
|
}
|
|
54
60
|
end
|
|
55
61
|
|
|
62
|
+
# Initializes the object
|
|
63
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
56
64
|
def initialize(attributes = {})
|
|
57
65
|
return unless attributes.is_a?(Hash)
|
|
58
66
|
|
|
59
67
|
# convert string to symbol for hash key
|
|
60
|
-
attributes = attributes.
|
|
68
|
+
attributes = attributes.each_with_object({}){|(k,v), h| h[k.to_sym] = v}
|
|
61
69
|
|
|
62
|
-
|
|
63
|
-
if attributes[:'lastName']
|
|
70
|
+
if attributes.has_key?(:'lastName')
|
|
64
71
|
self.last_name = attributes[:'lastName']
|
|
65
72
|
end
|
|
66
73
|
|
|
67
|
-
if attributes
|
|
74
|
+
if attributes.has_key?(:'contact')
|
|
68
75
|
self.contact = attributes[:'contact']
|
|
69
76
|
end
|
|
70
77
|
|
|
71
|
-
if attributes
|
|
78
|
+
if attributes.has_key?(:'firstName')
|
|
72
79
|
self.first_name = attributes[:'firstName']
|
|
73
80
|
end
|
|
74
81
|
|
|
75
|
-
if attributes
|
|
82
|
+
if attributes.has_key?(:'id')
|
|
76
83
|
self.id = attributes[:'id']
|
|
77
84
|
end
|
|
78
85
|
|
|
79
86
|
end
|
|
80
87
|
|
|
81
|
-
#
|
|
88
|
+
# Show invalid properties with the reasons. Usually used together with valid?
|
|
89
|
+
# @return Array for valid properies with the reasons
|
|
90
|
+
def list_invalid_properties
|
|
91
|
+
invalid_properties = Array.new
|
|
92
|
+
return invalid_properties
|
|
93
|
+
end
|
|
94
|
+
|
|
95
|
+
# Check to see if the all the properties in the model are valid
|
|
96
|
+
# @return true if the model is valid
|
|
97
|
+
def valid?
|
|
98
|
+
return true
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
# Checks equality by comparing each attribute.
|
|
102
|
+
# @param [Object] Object to be compared
|
|
82
103
|
def ==(o)
|
|
83
104
|
return true if self.equal?(o)
|
|
84
105
|
self.class == o.class &&
|
|
@@ -89,35 +110,41 @@ module SimplyRetsClient
|
|
|
89
110
|
end
|
|
90
111
|
|
|
91
112
|
# @see the `==` method
|
|
113
|
+
# @param [Object] Object to be compared
|
|
92
114
|
def eql?(o)
|
|
93
115
|
self == o
|
|
94
116
|
end
|
|
95
117
|
|
|
96
|
-
#
|
|
118
|
+
# Calculates hash code according to all attributes.
|
|
119
|
+
# @return [Fixnum] Hash code
|
|
97
120
|
def hash
|
|
98
121
|
[last_name, contact, first_name, id].hash
|
|
99
122
|
end
|
|
100
123
|
|
|
101
|
-
#
|
|
124
|
+
# Builds the object from hash
|
|
125
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
126
|
+
# @return [Object] Returns the model itself
|
|
102
127
|
def build_from_hash(attributes)
|
|
103
128
|
return nil unless attributes.is_a?(Hash)
|
|
104
129
|
self.class.swagger_types.each_pair do |key, type|
|
|
105
130
|
if type =~ /^Array<(.*)>/i
|
|
131
|
+
# check to ensure the input is an array given that the the attribute
|
|
132
|
+
# is documented as an array but the input is not
|
|
106
133
|
if attributes[self.class.attribute_map[key]].is_a?(Array)
|
|
107
134
|
self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } )
|
|
108
|
-
else
|
|
109
|
-
#TODO show warning in debug mode
|
|
110
135
|
end
|
|
111
136
|
elsif !attributes[self.class.attribute_map[key]].nil?
|
|
112
137
|
self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
|
|
113
|
-
else
|
|
114
|
-
# data not found in attributes(hash), not an issue as the data can be optional
|
|
115
|
-
end
|
|
138
|
+
end # or else data not found in attributes(hash), not an issue as the data can be optional
|
|
116
139
|
end
|
|
117
140
|
|
|
118
141
|
self
|
|
119
142
|
end
|
|
120
143
|
|
|
144
|
+
# Deserializes the data based on type
|
|
145
|
+
# @param string type Data type
|
|
146
|
+
# @param string value Value to be deserialized
|
|
147
|
+
# @return [Object] Deserialized data
|
|
121
148
|
def _deserialize(type, value)
|
|
122
149
|
case type.to_sym
|
|
123
150
|
when :DateTime
|
|
@@ -151,21 +178,25 @@ module SimplyRetsClient
|
|
|
151
178
|
end
|
|
152
179
|
end
|
|
153
180
|
else # model
|
|
154
|
-
|
|
155
|
-
|
|
181
|
+
temp_model = SimplyRetsClient.const_get(type).new
|
|
182
|
+
temp_model.build_from_hash(value)
|
|
156
183
|
end
|
|
157
184
|
end
|
|
158
185
|
|
|
186
|
+
# Returns the string representation of the object
|
|
187
|
+
# @return [String] String presentation of the object
|
|
159
188
|
def to_s
|
|
160
189
|
to_hash.to_s
|
|
161
190
|
end
|
|
162
191
|
|
|
163
|
-
# to_body is an alias to
|
|
192
|
+
# to_body is an alias to to_hash (backward compatibility)
|
|
193
|
+
# @return [Hash] Returns the object in the form of hash
|
|
164
194
|
def to_body
|
|
165
195
|
to_hash
|
|
166
196
|
end
|
|
167
197
|
|
|
168
|
-
#
|
|
198
|
+
# Returns the object in the form of hash
|
|
199
|
+
# @return [Hash] Returns the object in the form of hash
|
|
169
200
|
def to_hash
|
|
170
201
|
hash = {}
|
|
171
202
|
self.class.attribute_map.each_pair do |attr, param|
|
|
@@ -176,8 +207,10 @@ module SimplyRetsClient
|
|
|
176
207
|
hash
|
|
177
208
|
end
|
|
178
209
|
|
|
179
|
-
#
|
|
210
|
+
# Outputs non-array value in the form of hash
|
|
180
211
|
# For object, use to_hash. Otherwise, just return the value
|
|
212
|
+
# @param [Object] value Any valid value
|
|
213
|
+
# @return [Hash] Returns the value in the form of hash
|
|
181
214
|
def _to_hash(value)
|
|
182
215
|
if value.is_a?(Array)
|
|
183
216
|
value.compact.map{ |v| _to_hash(v) }
|
|
@@ -193,4 +226,5 @@ module SimplyRetsClient
|
|
|
193
226
|
end
|
|
194
227
|
|
|
195
228
|
end
|
|
229
|
+
|
|
196
230
|
end
|
|
@@ -1,12 +1,23 @@
|
|
|
1
1
|
=begin
|
|
2
2
|
SimplyRETS API
|
|
3
3
|
|
|
4
|
-
The SimplyRETS API is an exciting step towards making it easier for
|
|
4
|
+
The SimplyRETS API is an exciting step towards making it easier for developers and real estate agents to build something awesome with real estate data! The documentation below makes live requests to our API using the trial data. To get set up with the API using live MLS data, you must have RETS credentials from your MLS, which you can then use to create an app with SimplyRETS. For more information on that process, please see our [FAQ](https://simplyrets.com/faq), [Getting Started](https://simplyrets.com/blog/getting-set-up.html) page, or [contact us](https://simplyrets.com/\\#home-contact). Below you'll find the API endpoints, query parameters, response bodies, and other information about using the SimplyRETS API. You can run queries by clicking the 'Try it Out' button at the bottom of each section. ### Authentication The SimplyRETS API uses Basic Authentication. When you create an app, you'll get a set of API credentials to access your listings. If you're trying out the test data, you can use `simplyrets:simplyrets` for connecting to the API. ### Media Types The SimplyRETS API uses the `Accept` header to allow clients to control media types (content versions). We maintain backwards compatibility with API clients by allowing them to specify a content version. We highly recommend setting and explicity media type when your application reaches production. Both the structure and content of our API response bodies is subject to change so we can add new features while respecting the stability of applications which have already been developed. To always use the latest SimplyRETS content version, simply use `application/json` in your application `Accept` header. If you want to pin your clients media type to a specific version, you can use the vendor-specific SimplyRETS media type, e.g. `application/vnd.simplyrets-v0.1+json\"` To view all valid content-types for making an `OPTIONS`, make a request to the SimplyRETS api root `curl -XOPTIONS -u simplyrets:simplyrets https://api.simplyrets.com/` The default media types used in our API responses may change in the future. If you're building an application and care about the stability of the API, be sure to request a specific media type in the Accept header as shown in the examples below. The wordpress plugin automatically sets the `Accept` header for the compatible SimplyRETS media types. ### Pagination There a few pieces of useful information about each request stored in the HTTP Headers: - `X-Total-Count` shows you the total amount of listings that match your current query. - `Link` contains pre-built pagination links for accessing the next 'page' of listings that match your query. Read more about that [here](https://simplyrets.com/blog/api-pagination.html).
|
|
5
5
|
|
|
6
6
|
OpenAPI spec version: 1.0.0
|
|
7
7
|
|
|
8
8
|
Generated by: https://github.com/swagger-api/swagger-codegen.git
|
|
9
9
|
|
|
10
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
you may not use this file except in compliance with the License.
|
|
12
|
+
You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
See the License for the specific language governing permissions and
|
|
20
|
+
limitations under the License.
|
|
10
21
|
|
|
11
22
|
=end
|
|
12
23
|
|
|
@@ -18,12 +29,11 @@ module SimplyRetsClient
|
|
|
18
29
|
# Start Date
|
|
19
30
|
attr_accessor :startdate
|
|
20
31
|
|
|
32
|
+
|
|
21
33
|
# Attribute mapping from ruby-style variable name to JSON key.
|
|
22
34
|
def self.attribute_map
|
|
23
35
|
{
|
|
24
|
-
|
|
25
36
|
:'startdate' => :'startdate'
|
|
26
|
-
|
|
27
37
|
}
|
|
28
38
|
end
|
|
29
39
|
|
|
@@ -31,24 +41,38 @@ module SimplyRetsClient
|
|
|
31
41
|
def self.swagger_types
|
|
32
42
|
{
|
|
33
43
|
:'startdate' => :'DateTime'
|
|
34
|
-
|
|
35
44
|
}
|
|
36
45
|
end
|
|
37
46
|
|
|
47
|
+
# Initializes the object
|
|
48
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
38
49
|
def initialize(attributes = {})
|
|
39
50
|
return unless attributes.is_a?(Hash)
|
|
40
51
|
|
|
41
52
|
# convert string to symbol for hash key
|
|
42
|
-
attributes = attributes.
|
|
43
|
-
|
|
53
|
+
attributes = attributes.each_with_object({}){|(k,v), h| h[k.to_sym] = v}
|
|
44
54
|
|
|
45
|
-
if attributes
|
|
55
|
+
if attributes.has_key?(:'startdate')
|
|
46
56
|
self.startdate = attributes[:'startdate']
|
|
47
57
|
end
|
|
48
58
|
|
|
49
59
|
end
|
|
50
60
|
|
|
51
|
-
#
|
|
61
|
+
# Show invalid properties with the reasons. Usually used together with valid?
|
|
62
|
+
# @return Array for valid properies with the reasons
|
|
63
|
+
def list_invalid_properties
|
|
64
|
+
invalid_properties = Array.new
|
|
65
|
+
return invalid_properties
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
# Check to see if the all the properties in the model are valid
|
|
69
|
+
# @return true if the model is valid
|
|
70
|
+
def valid?
|
|
71
|
+
return true
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
# Checks equality by comparing each attribute.
|
|
75
|
+
# @param [Object] Object to be compared
|
|
52
76
|
def ==(o)
|
|
53
77
|
return true if self.equal?(o)
|
|
54
78
|
self.class == o.class &&
|
|
@@ -56,35 +80,41 @@ module SimplyRetsClient
|
|
|
56
80
|
end
|
|
57
81
|
|
|
58
82
|
# @see the `==` method
|
|
83
|
+
# @param [Object] Object to be compared
|
|
59
84
|
def eql?(o)
|
|
60
85
|
self == o
|
|
61
86
|
end
|
|
62
87
|
|
|
63
|
-
#
|
|
88
|
+
# Calculates hash code according to all attributes.
|
|
89
|
+
# @return [Fixnum] Hash code
|
|
64
90
|
def hash
|
|
65
91
|
[startdate].hash
|
|
66
92
|
end
|
|
67
93
|
|
|
68
|
-
#
|
|
94
|
+
# Builds the object from hash
|
|
95
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
96
|
+
# @return [Object] Returns the model itself
|
|
69
97
|
def build_from_hash(attributes)
|
|
70
98
|
return nil unless attributes.is_a?(Hash)
|
|
71
99
|
self.class.swagger_types.each_pair do |key, type|
|
|
72
100
|
if type =~ /^Array<(.*)>/i
|
|
101
|
+
# check to ensure the input is an array given that the the attribute
|
|
102
|
+
# is documented as an array but the input is not
|
|
73
103
|
if attributes[self.class.attribute_map[key]].is_a?(Array)
|
|
74
104
|
self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } )
|
|
75
|
-
else
|
|
76
|
-
#TODO show warning in debug mode
|
|
77
105
|
end
|
|
78
106
|
elsif !attributes[self.class.attribute_map[key]].nil?
|
|
79
107
|
self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
|
|
80
|
-
else
|
|
81
|
-
# data not found in attributes(hash), not an issue as the data can be optional
|
|
82
|
-
end
|
|
108
|
+
end # or else data not found in attributes(hash), not an issue as the data can be optional
|
|
83
109
|
end
|
|
84
110
|
|
|
85
111
|
self
|
|
86
112
|
end
|
|
87
113
|
|
|
114
|
+
# Deserializes the data based on type
|
|
115
|
+
# @param string type Data type
|
|
116
|
+
# @param string value Value to be deserialized
|
|
117
|
+
# @return [Object] Deserialized data
|
|
88
118
|
def _deserialize(type, value)
|
|
89
119
|
case type.to_sym
|
|
90
120
|
when :DateTime
|
|
@@ -118,21 +148,25 @@ module SimplyRetsClient
|
|
|
118
148
|
end
|
|
119
149
|
end
|
|
120
150
|
else # model
|
|
121
|
-
|
|
122
|
-
|
|
151
|
+
temp_model = SimplyRetsClient.const_get(type).new
|
|
152
|
+
temp_model.build_from_hash(value)
|
|
123
153
|
end
|
|
124
154
|
end
|
|
125
155
|
|
|
156
|
+
# Returns the string representation of the object
|
|
157
|
+
# @return [String] String presentation of the object
|
|
126
158
|
def to_s
|
|
127
159
|
to_hash.to_s
|
|
128
160
|
end
|
|
129
161
|
|
|
130
|
-
# to_body is an alias to
|
|
162
|
+
# to_body is an alias to to_hash (backward compatibility)
|
|
163
|
+
# @return [Hash] Returns the object in the form of hash
|
|
131
164
|
def to_body
|
|
132
165
|
to_hash
|
|
133
166
|
end
|
|
134
167
|
|
|
135
|
-
#
|
|
168
|
+
# Returns the object in the form of hash
|
|
169
|
+
# @return [Hash] Returns the object in the form of hash
|
|
136
170
|
def to_hash
|
|
137
171
|
hash = {}
|
|
138
172
|
self.class.attribute_map.each_pair do |attr, param|
|
|
@@ -143,8 +177,10 @@ module SimplyRetsClient
|
|
|
143
177
|
hash
|
|
144
178
|
end
|
|
145
179
|
|
|
146
|
-
#
|
|
180
|
+
# Outputs non-array value in the form of hash
|
|
147
181
|
# For object, use to_hash. Otherwise, just return the value
|
|
182
|
+
# @param [Object] value Any valid value
|
|
183
|
+
# @return [Hash] Returns the value in the form of hash
|
|
148
184
|
def _to_hash(value)
|
|
149
185
|
if value.is_a?(Array)
|
|
150
186
|
value.compact.map{ |v| _to_hash(v) }
|
|
@@ -160,4 +196,5 @@ module SimplyRetsClient
|
|
|
160
196
|
end
|
|
161
197
|
|
|
162
198
|
end
|
|
199
|
+
|
|
163
200
|
end
|
|
@@ -1,12 +1,23 @@
|
|
|
1
1
|
=begin
|
|
2
2
|
SimplyRETS API
|
|
3
3
|
|
|
4
|
-
The SimplyRETS API is an exciting step towards making it easier for
|
|
4
|
+
The SimplyRETS API is an exciting step towards making it easier for developers and real estate agents to build something awesome with real estate data! The documentation below makes live requests to our API using the trial data. To get set up with the API using live MLS data, you must have RETS credentials from your MLS, which you can then use to create an app with SimplyRETS. For more information on that process, please see our [FAQ](https://simplyrets.com/faq), [Getting Started](https://simplyrets.com/blog/getting-set-up.html) page, or [contact us](https://simplyrets.com/\\#home-contact). Below you'll find the API endpoints, query parameters, response bodies, and other information about using the SimplyRETS API. You can run queries by clicking the 'Try it Out' button at the bottom of each section. ### Authentication The SimplyRETS API uses Basic Authentication. When you create an app, you'll get a set of API credentials to access your listings. If you're trying out the test data, you can use `simplyrets:simplyrets` for connecting to the API. ### Media Types The SimplyRETS API uses the `Accept` header to allow clients to control media types (content versions). We maintain backwards compatibility with API clients by allowing them to specify a content version. We highly recommend setting and explicity media type when your application reaches production. Both the structure and content of our API response bodies is subject to change so we can add new features while respecting the stability of applications which have already been developed. To always use the latest SimplyRETS content version, simply use `application/json` in your application `Accept` header. If you want to pin your clients media type to a specific version, you can use the vendor-specific SimplyRETS media type, e.g. `application/vnd.simplyrets-v0.1+json\"` To view all valid content-types for making an `OPTIONS`, make a request to the SimplyRETS api root `curl -XOPTIONS -u simplyrets:simplyrets https://api.simplyrets.com/` The default media types used in our API responses may change in the future. If you're building an application and care about the stability of the API, be sure to request a specific media type in the Accept header as shown in the examples below. The wordpress plugin automatically sets the `Accept` header for the compatible SimplyRETS media types. ### Pagination There a few pieces of useful information about each request stored in the HTTP Headers: - `X-Total-Count` shows you the total amount of listings that match your current query. - `Link` contains pre-built pagination links for accessing the next 'page' of listings that match your query. Read more about that [here](https://simplyrets.com/blog/api-pagination.html).
|
|
5
5
|
|
|
6
6
|
OpenAPI spec version: 1.0.0
|
|
7
7
|
|
|
8
8
|
Generated by: https://github.com/swagger-api/swagger-codegen.git
|
|
9
9
|
|
|
10
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
11
|
+
you may not use this file except in compliance with the License.
|
|
12
|
+
You may obtain a copy of the License at
|
|
13
|
+
|
|
14
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
15
|
+
|
|
16
|
+
Unless required by applicable law or agreed to in writing, software
|
|
17
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
18
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
19
|
+
See the License for the specific language governing permissions and
|
|
20
|
+
limitations under the License.
|
|
10
21
|
|
|
11
22
|
=end
|
|
12
23
|
|
|
@@ -15,25 +26,22 @@ require 'date'
|
|
|
15
26
|
module SimplyRetsClient
|
|
16
27
|
# RETS MLS Contact Information
|
|
17
28
|
class ContactInformation
|
|
18
|
-
# The email address of the `ContactInformation
|
|
29
|
+
# The email address of the `ContactInformation` **Not available for all RETS vendors**
|
|
19
30
|
attr_accessor :email
|
|
20
31
|
|
|
21
|
-
# Contact Information Office Phone Number
|
|
32
|
+
# Contact Information Office Phone Number **Not available for all RETS vendors**
|
|
22
33
|
attr_accessor :office
|
|
23
34
|
|
|
24
|
-
# Contact Information Cell Phone
|
|
35
|
+
# Contact Information Cell Phone **Not available for all RETS vendors**
|
|
25
36
|
attr_accessor :cell
|
|
26
37
|
|
|
38
|
+
|
|
27
39
|
# Attribute mapping from ruby-style variable name to JSON key.
|
|
28
40
|
def self.attribute_map
|
|
29
41
|
{
|
|
30
|
-
|
|
31
42
|
:'email' => :'email',
|
|
32
|
-
|
|
33
43
|
:'office' => :'office',
|
|
34
|
-
|
|
35
44
|
:'cell' => :'cell'
|
|
36
|
-
|
|
37
45
|
}
|
|
38
46
|
end
|
|
39
47
|
|
|
@@ -43,32 +51,46 @@ module SimplyRetsClient
|
|
|
43
51
|
:'email' => :'String',
|
|
44
52
|
:'office' => :'String',
|
|
45
53
|
:'cell' => :'String'
|
|
46
|
-
|
|
47
54
|
}
|
|
48
55
|
end
|
|
49
56
|
|
|
57
|
+
# Initializes the object
|
|
58
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
50
59
|
def initialize(attributes = {})
|
|
51
60
|
return unless attributes.is_a?(Hash)
|
|
52
61
|
|
|
53
62
|
# convert string to symbol for hash key
|
|
54
|
-
attributes = attributes.
|
|
63
|
+
attributes = attributes.each_with_object({}){|(k,v), h| h[k.to_sym] = v}
|
|
55
64
|
|
|
56
|
-
|
|
57
|
-
if attributes[:'email']
|
|
65
|
+
if attributes.has_key?(:'email')
|
|
58
66
|
self.email = attributes[:'email']
|
|
59
67
|
end
|
|
60
68
|
|
|
61
|
-
if attributes
|
|
69
|
+
if attributes.has_key?(:'office')
|
|
62
70
|
self.office = attributes[:'office']
|
|
63
71
|
end
|
|
64
72
|
|
|
65
|
-
if attributes
|
|
73
|
+
if attributes.has_key?(:'cell')
|
|
66
74
|
self.cell = attributes[:'cell']
|
|
67
75
|
end
|
|
68
76
|
|
|
69
77
|
end
|
|
70
78
|
|
|
71
|
-
#
|
|
79
|
+
# Show invalid properties with the reasons. Usually used together with valid?
|
|
80
|
+
# @return Array for valid properies with the reasons
|
|
81
|
+
def list_invalid_properties
|
|
82
|
+
invalid_properties = Array.new
|
|
83
|
+
return invalid_properties
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
# Check to see if the all the properties in the model are valid
|
|
87
|
+
# @return true if the model is valid
|
|
88
|
+
def valid?
|
|
89
|
+
return true
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
# Checks equality by comparing each attribute.
|
|
93
|
+
# @param [Object] Object to be compared
|
|
72
94
|
def ==(o)
|
|
73
95
|
return true if self.equal?(o)
|
|
74
96
|
self.class == o.class &&
|
|
@@ -78,35 +100,41 @@ module SimplyRetsClient
|
|
|
78
100
|
end
|
|
79
101
|
|
|
80
102
|
# @see the `==` method
|
|
103
|
+
# @param [Object] Object to be compared
|
|
81
104
|
def eql?(o)
|
|
82
105
|
self == o
|
|
83
106
|
end
|
|
84
107
|
|
|
85
|
-
#
|
|
108
|
+
# Calculates hash code according to all attributes.
|
|
109
|
+
# @return [Fixnum] Hash code
|
|
86
110
|
def hash
|
|
87
111
|
[email, office, cell].hash
|
|
88
112
|
end
|
|
89
113
|
|
|
90
|
-
#
|
|
114
|
+
# Builds the object from hash
|
|
115
|
+
# @param [Hash] attributes Model attributes in the form of hash
|
|
116
|
+
# @return [Object] Returns the model itself
|
|
91
117
|
def build_from_hash(attributes)
|
|
92
118
|
return nil unless attributes.is_a?(Hash)
|
|
93
119
|
self.class.swagger_types.each_pair do |key, type|
|
|
94
120
|
if type =~ /^Array<(.*)>/i
|
|
121
|
+
# check to ensure the input is an array given that the the attribute
|
|
122
|
+
# is documented as an array but the input is not
|
|
95
123
|
if attributes[self.class.attribute_map[key]].is_a?(Array)
|
|
96
124
|
self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } )
|
|
97
|
-
else
|
|
98
|
-
#TODO show warning in debug mode
|
|
99
125
|
end
|
|
100
126
|
elsif !attributes[self.class.attribute_map[key]].nil?
|
|
101
127
|
self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
|
|
102
|
-
else
|
|
103
|
-
# data not found in attributes(hash), not an issue as the data can be optional
|
|
104
|
-
end
|
|
128
|
+
end # or else data not found in attributes(hash), not an issue as the data can be optional
|
|
105
129
|
end
|
|
106
130
|
|
|
107
131
|
self
|
|
108
132
|
end
|
|
109
133
|
|
|
134
|
+
# Deserializes the data based on type
|
|
135
|
+
# @param string type Data type
|
|
136
|
+
# @param string value Value to be deserialized
|
|
137
|
+
# @return [Object] Deserialized data
|
|
110
138
|
def _deserialize(type, value)
|
|
111
139
|
case type.to_sym
|
|
112
140
|
when :DateTime
|
|
@@ -140,21 +168,25 @@ module SimplyRetsClient
|
|
|
140
168
|
end
|
|
141
169
|
end
|
|
142
170
|
else # model
|
|
143
|
-
|
|
144
|
-
|
|
171
|
+
temp_model = SimplyRetsClient.const_get(type).new
|
|
172
|
+
temp_model.build_from_hash(value)
|
|
145
173
|
end
|
|
146
174
|
end
|
|
147
175
|
|
|
176
|
+
# Returns the string representation of the object
|
|
177
|
+
# @return [String] String presentation of the object
|
|
148
178
|
def to_s
|
|
149
179
|
to_hash.to_s
|
|
150
180
|
end
|
|
151
181
|
|
|
152
|
-
# to_body is an alias to
|
|
182
|
+
# to_body is an alias to to_hash (backward compatibility)
|
|
183
|
+
# @return [Hash] Returns the object in the form of hash
|
|
153
184
|
def to_body
|
|
154
185
|
to_hash
|
|
155
186
|
end
|
|
156
187
|
|
|
157
|
-
#
|
|
188
|
+
# Returns the object in the form of hash
|
|
189
|
+
# @return [Hash] Returns the object in the form of hash
|
|
158
190
|
def to_hash
|
|
159
191
|
hash = {}
|
|
160
192
|
self.class.attribute_map.each_pair do |attr, param|
|
|
@@ -165,8 +197,10 @@ module SimplyRetsClient
|
|
|
165
197
|
hash
|
|
166
198
|
end
|
|
167
199
|
|
|
168
|
-
#
|
|
200
|
+
# Outputs non-array value in the form of hash
|
|
169
201
|
# For object, use to_hash. Otherwise, just return the value
|
|
202
|
+
# @param [Object] value Any valid value
|
|
203
|
+
# @return [Hash] Returns the value in the form of hash
|
|
170
204
|
def _to_hash(value)
|
|
171
205
|
if value.is_a?(Array)
|
|
172
206
|
value.compact.map{ |v| _to_hash(v) }
|
|
@@ -182,4 +216,5 @@ module SimplyRetsClient
|
|
|
182
216
|
end
|
|
183
217
|
|
|
184
218
|
end
|
|
219
|
+
|
|
185
220
|
end
|