kontent-delivery-sdk-ruby 2.0.6 → 2.0.7

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.
Files changed (44) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.md +21 -21
  3. data/README.md +511 -511
  4. data/bin/console +14 -14
  5. data/bin/setup +8 -8
  6. data/lib/delivery/builders/image_transformation_builder.rb +271 -271
  7. data/lib/delivery/builders/url_builder.rb +117 -117
  8. data/lib/delivery/client/delivery_client.rb +155 -155
  9. data/lib/delivery/client/delivery_query.rb +249 -249
  10. data/lib/delivery/client/request_manager.rb +107 -107
  11. data/lib/delivery/models/content_item.rb +153 -153
  12. data/lib/delivery/models/content_type.rb +41 -41
  13. data/lib/delivery/models/pagination.rb +21 -21
  14. data/lib/delivery/models/taxonomy_group.rb +39 -39
  15. data/lib/delivery/query_parameters/filters.rb +158 -158
  16. data/lib/delivery/query_parameters/parameter_base.rb +44 -44
  17. data/lib/delivery/query_parameters/query_string.rb +78 -78
  18. data/lib/delivery/resolvers/content_link_resolver.rb +102 -102
  19. data/lib/delivery/resolvers/inline_content_item_resolver.rb +75 -75
  20. data/lib/delivery/resolvers/linked_item_resolver.rb +37 -37
  21. data/lib/delivery/responses/delivery_element_response.rb +33 -33
  22. data/lib/delivery/responses/delivery_item_listing_response.rb +53 -53
  23. data/lib/delivery/responses/delivery_item_response.rb +39 -39
  24. data/lib/delivery/responses/delivery_taxonomy_listing_response.rb +46 -46
  25. data/lib/delivery/responses/delivery_taxonomy_response.rb +32 -32
  26. data/lib/delivery/responses/delivery_type_listing_response.rb +45 -45
  27. data/lib/delivery/responses/delivery_type_response.rb +31 -31
  28. data/lib/delivery/responses/response_base.rb +36 -36
  29. data/lib/delivery/tests/401.json +5 -5
  30. data/lib/delivery/tests/fake_responder.rb +67 -67
  31. data/lib/delivery/tests/filtering/items_gt.json +565 -565
  32. data/lib/delivery/tests/filtering/multiple.json +282 -282
  33. data/lib/delivery/tests/filtering/pagination_about_us.json +646 -646
  34. data/lib/delivery/tests/generic/items/about_us.json +227 -227
  35. data/lib/delivery/tests/generic/items/aeropress_filters.json +138 -138
  36. data/lib/delivery/tests/generic/items/coffee_processing_techniques.json +168 -168
  37. data/lib/delivery/tests/generic/items/where_does_coffee_come_from_.json +620 -620
  38. data/lib/delivery/tests/generic/items.json +4984 -4984
  39. data/lib/delivery/tests/generic/taxonomies.json +126 -126
  40. data/lib/delivery/tests/generic/types/brewer/elements/product_status.json +5 -5
  41. data/lib/delivery/tests/generic/types.json +780 -780
  42. data/lib/delivery/version.rb +7 -7
  43. data/lib/kontent-delivery-sdk-ruby.rb +19 -19
  44. metadata +12 -13
@@ -1,117 +1,117 @@
1
- module Kentico
2
- module Kontent
3
- module Delivery
4
- module Builders
5
- # Internal class which generates the URL required for Delivery REST API
6
- class UrlBuilder
7
- URL_TEMPLATE_BASE = 'https://deliver.kontent.ai/%s'.freeze
8
- URL_TEMPLATE_PREVIEW = 'https://preview-deliver.kontent.ai/%s'.freeze
9
- URL_TEMPLATE_ITEM = '/items/%s'.freeze
10
- URL_TEMPLATE_ITEMS = '/items'.freeze
11
- URL_TEMPLATE_TYPE = '/types/%s'.freeze
12
- URL_TEMPLATE_TYPES = '/types'.freeze
13
- URL_TEMPLATE_ELEMENTS = '/types/%s/elements/%s'.freeze
14
- URL_TEMPLATE_TAXONOMY = '/taxonomies/%s'.freeze
15
- URL_TEMPLATE_TAXONOMIES = '/taxonomies'.freeze
16
-
17
- URL_MAX_LENGTH = 65_519
18
- MSG_LONG_QUERY = 'The request url is too long. Split your query into multiple calls.'.freeze
19
-
20
- class << self
21
- # Returns the proper domain for the request along with the
22
- # query string parameters configured by the +DeliveryQuery+.
23
- #
24
- # * *Args*:
25
- # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
26
- #
27
- # * *Returns*:
28
- # - +string+ The full URL for a Delivery request
29
- def provide_url(query)
30
- url = provide_base_url(query)
31
- url += provide_path_part(query)
32
-
33
- if query.query_string.empty?
34
- url
35
- else
36
- url + query.query_string.to_s
37
- end
38
- end
39
-
40
- # Checks whether the provided URL is too long and raises an error if so.
41
- #
42
- # * *Args*:
43
- # - *url* (+string+) A full Delivery URL
44
- #
45
- # * *Raises*:
46
- # - +UriFormatException+ if the URL is 65,519 characters or more
47
- def validate_url(url)
48
- raise UriFormatException, MSG_LONG_QUERY if url.length > URL_MAX_LENGTH
49
- end
50
-
51
- private
52
-
53
- # Returns relative path part of URL depending on query type.
54
- #
55
- # * *Args*:
56
- # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
57
- #
58
- # * *Returns*:
59
- # - +string+ The URL path part (without protocol or domain)
60
- def provide_path_part(query)
61
- case query.query_type
62
- when Kentico::Kontent::Delivery::QUERY_TYPE_ITEMS
63
- provide_item query
64
- when Kentico::Kontent::Delivery::QUERY_TYPE_TYPES
65
- provide_type query
66
- when Kentico::Kontent::Delivery::QUERY_TYPE_TAXONOMIES
67
- provide_taxonomy query
68
- when Kentico::Kontent::Delivery::QUERY_TYPE_ELEMENT
69
- format(URL_TEMPLATE_ELEMENTS, query.content_type, query.code_name)
70
- end
71
- end
72
-
73
- def provide_item(query)
74
- if query.code_name.nil?
75
- URL_TEMPLATE_ITEMS
76
- else
77
- format(URL_TEMPLATE_ITEM, query.code_name)
78
- end
79
- end
80
-
81
- def provide_taxonomy(query)
82
- if query.code_name.nil?
83
- URL_TEMPLATE_TAXONOMIES
84
- else
85
- format(URL_TEMPLATE_TAXONOMY, query.code_name)
86
- end
87
- end
88
-
89
- def provide_type(query)
90
- if query.code_name.nil?
91
- URL_TEMPLATE_TYPES
92
- else
93
- format(URL_TEMPLATE_TYPE, query.code_name)
94
- end
95
- end
96
-
97
- # Returns the protocol and domain with project ID. Domain changes
98
- # according to the query's +use_preview+ attribute.
99
- #
100
- # * *Args*:
101
- # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
102
- #
103
- # * *Returns*:
104
- # - +string+ The URL with the project ID
105
- def provide_base_url(query)
106
- if query.use_preview
107
- format(URL_TEMPLATE_PREVIEW, query.project_id)
108
- else
109
- format(URL_TEMPLATE_BASE, query.project_id)
110
- end
111
- end
112
- end
113
- end
114
- end
115
- end
116
- end
117
- end
1
+ module Kentico
2
+ module Kontent
3
+ module Delivery
4
+ module Builders
5
+ # Internal class which generates the URL required for Delivery REST API
6
+ class UrlBuilder
7
+ URL_TEMPLATE_BASE = 'https://deliver.kontent.ai/%s'.freeze
8
+ URL_TEMPLATE_PREVIEW = 'https://preview-deliver.kontent.ai/%s'.freeze
9
+ URL_TEMPLATE_ITEM = '/items/%s'.freeze
10
+ URL_TEMPLATE_ITEMS = '/items'.freeze
11
+ URL_TEMPLATE_TYPE = '/types/%s'.freeze
12
+ URL_TEMPLATE_TYPES = '/types'.freeze
13
+ URL_TEMPLATE_ELEMENTS = '/types/%s/elements/%s'.freeze
14
+ URL_TEMPLATE_TAXONOMY = '/taxonomies/%s'.freeze
15
+ URL_TEMPLATE_TAXONOMIES = '/taxonomies'.freeze
16
+
17
+ URL_MAX_LENGTH = 65_519
18
+ MSG_LONG_QUERY = 'The request url is too long. Split your query into multiple calls.'.freeze
19
+
20
+ class << self
21
+ # Returns the proper domain for the request along with the
22
+ # query string parameters configured by the +DeliveryQuery+.
23
+ #
24
+ # * *Args*:
25
+ # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
26
+ #
27
+ # * *Returns*:
28
+ # - +string+ The full URL for a Delivery request
29
+ def provide_url(query)
30
+ url = provide_base_url(query)
31
+ url += provide_path_part(query)
32
+
33
+ if query.query_string.empty?
34
+ url
35
+ else
36
+ url + query.query_string.to_s
37
+ end
38
+ end
39
+
40
+ # Checks whether the provided URL is too long and raises an error if so.
41
+ #
42
+ # * *Args*:
43
+ # - *url* (+string+) A full Delivery URL
44
+ #
45
+ # * *Raises*:
46
+ # - +UriFormatException+ if the URL is 65,519 characters or more
47
+ def validate_url(url)
48
+ raise UriFormatException, MSG_LONG_QUERY if url.length > URL_MAX_LENGTH
49
+ end
50
+
51
+ private
52
+
53
+ # Returns relative path part of URL depending on query type.
54
+ #
55
+ # * *Args*:
56
+ # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
57
+ #
58
+ # * *Returns*:
59
+ # - +string+ The URL path part (without protocol or domain)
60
+ def provide_path_part(query)
61
+ case query.query_type
62
+ when Kentico::Kontent::Delivery::QUERY_TYPE_ITEMS
63
+ provide_item query
64
+ when Kentico::Kontent::Delivery::QUERY_TYPE_TYPES
65
+ provide_type query
66
+ when Kentico::Kontent::Delivery::QUERY_TYPE_TAXONOMIES
67
+ provide_taxonomy query
68
+ when Kentico::Kontent::Delivery::QUERY_TYPE_ELEMENT
69
+ format(URL_TEMPLATE_ELEMENTS, query.content_type, query.code_name)
70
+ end
71
+ end
72
+
73
+ def provide_item(query)
74
+ if query.code_name.nil?
75
+ URL_TEMPLATE_ITEMS
76
+ else
77
+ format(URL_TEMPLATE_ITEM, query.code_name)
78
+ end
79
+ end
80
+
81
+ def provide_taxonomy(query)
82
+ if query.code_name.nil?
83
+ URL_TEMPLATE_TAXONOMIES
84
+ else
85
+ format(URL_TEMPLATE_TAXONOMY, query.code_name)
86
+ end
87
+ end
88
+
89
+ def provide_type(query)
90
+ if query.code_name.nil?
91
+ URL_TEMPLATE_TYPES
92
+ else
93
+ format(URL_TEMPLATE_TYPE, query.code_name)
94
+ end
95
+ end
96
+
97
+ # Returns the protocol and domain with project ID. Domain changes
98
+ # according to the query's +use_preview+ attribute.
99
+ #
100
+ # * *Args*:
101
+ # - *query* ( Kentico::Kontent::Delivery::DeliveryQuery )
102
+ #
103
+ # * *Returns*:
104
+ # - +string+ The URL with the project ID
105
+ def provide_base_url(query)
106
+ if query.use_preview
107
+ format(URL_TEMPLATE_PREVIEW, query.project_id)
108
+ else
109
+ format(URL_TEMPLATE_BASE, query.project_id)
110
+ end
111
+ end
112
+ end
113
+ end
114
+ end
115
+ end
116
+ end
117
+ end
@@ -1,155 +1,155 @@
1
- require 'delivery/client/delivery_query'
2
- require 'delivery/responses/delivery_item_listing_response'
3
- require 'delivery/responses/delivery_item_response'
4
- require 'json'
5
-
6
- module Kentico
7
- module Kontent
8
- module Delivery
9
- QUERY_TYPE_TYPES = 'QUERY_TYPE_TYPES'.freeze
10
- QUERY_TYPE_ITEMS = 'QUERY_TYPE_ITEMS'.freeze
11
- QUERY_TYPE_TAXONOMIES = 'QUERY_TYPE_TAXONOMIES'.freeze
12
- QUERY_TYPE_ELEMENT = 'QUERY_TYPE_ELEMENT'.freeze
13
-
14
- # Executes requests against the Kentico Kontent Delivery API.
15
- class DeliveryClient
16
- attr_accessor :use_preview
17
-
18
- # Constructor. Accepts a hash with the options for client.
19
- #
20
- # * *Args*:
21
- # - *config* (+Hash+) May contain the following keys:
22
- # - project_id (+string+) _required_
23
- # - preview_key (+string+)
24
- # - secure_key (+string+)
25
- # - content_link_url_resolver ( Kentico::Kontent::Delivery::Resolvers::ContentLinkResolver )
26
- # - inline_content_item_resolver ( Kentico::Kontent::Delivery::Resolvers::InlineContentItemResolver )
27
- # - with_retry_policy (+bool+)
28
- def initialize(config)
29
- @project_id = config.fetch(:project_id)
30
- @preview_key = config.fetch(:preview_key, nil)
31
- @secure_key = config.fetch(:secure_key, nil)
32
- @content_link_url_resolver = config.fetch(:content_link_url_resolver, nil)
33
- @inline_content_item_resolver = config.fetch(:inline_content_item_resolver, nil)
34
- @with_retry_policy = config.fetch(:with_retry_policy, true)
35
- self.use_preview = !@preview_key.nil?
36
- end
37
-
38
- # Return all content types of the project
39
- #
40
- # * *Returns*:
41
- # - Kentico::Kontent::Delivery::DeliveryQuery
42
- def types
43
- DeliveryQuery.new project_id: @project_id,
44
- secure_key: @secure_key,
45
- query_type: QUERY_TYPE_TYPES,
46
- with_retry_policy: @with_retry_policy
47
- end
48
-
49
- # Return a single content type of the project
50
- #
51
- # * *Args*:
52
- # - *code_name* (+string+) Code name of the desired content type
53
- #
54
- # * *Returns*:
55
- # - Kentico::Kontent::Delivery::DeliveryQuery
56
- def type(code_name)
57
- DeliveryQuery.new project_id: @project_id,
58
- secure_key: @secure_key,
59
- code_name: code_name,
60
- query_type: QUERY_TYPE_TYPES,
61
- with_retry_policy: @with_retry_policy
62
- end
63
-
64
- # Return all content items of the project
65
- #
66
- # * *Args*:
67
- # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
68
- #
69
- # * *Returns*:
70
- # - Kentico::Kontent::Delivery::DeliveryQuery
71
- def items(query_parameters = [])
72
- q = DeliveryQuery.new project_id: @project_id,
73
- secure_key: @secure_key,
74
- qp: query_parameters,
75
- content_link_url_resolver: @content_link_url_resolver,
76
- inline_content_item_resolver: @inline_content_item_resolver,
77
- query_type: QUERY_TYPE_ITEMS,
78
- with_retry_policy: @with_retry_policy
79
- q.use_preview = use_preview
80
- q.preview_key = @preview_key
81
- q
82
- end
83
-
84
- # Return a single content item of the project
85
- #
86
- # * *Args*:
87
- # - *code_name* (+string+) The code name of the desired content item
88
- # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
89
- #
90
- # * *Returns*:
91
- # - Kentico::Kontent::Delivery::DeliveryQuery
92
- def item(code_name, query_parameters = [])
93
- q = DeliveryQuery.new project_id: @project_id,
94
- secure_key: @secure_key,
95
- code_name: code_name,
96
- qp: query_parameters,
97
- content_link_url_resolver: @content_link_url_resolver,
98
- inline_content_item_resolver: @inline_content_item_resolver,
99
- query_type: QUERY_TYPE_ITEMS,
100
- with_retry_policy: @with_retry_policy
101
- q.use_preview = use_preview
102
- q.preview_key = @preview_key
103
- q
104
- end
105
-
106
- # Return all taxonomy groups of the project
107
- #
108
- # * *Args*:
109
- # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
110
- #
111
- # * *Returns*:
112
- # - Kentico::Kontent::Delivery::DeliveryQuery
113
- def taxonomies(query_parameters = [])
114
- DeliveryQuery.new project_id: @project_id,
115
- secure_key: @secure_key,
116
- qp: query_parameters,
117
- query_type: QUERY_TYPE_TAXONOMIES,
118
- with_retry_policy: @with_retry_policy
119
- end
120
-
121
- # Return a single taxonomy group of the project
122
- #
123
- # * *Args*:
124
- # - *code_name* (+string+) The code name of the desired taxonomy group
125
- #
126
- # * *Returns*:
127
- # - Kentico::Kontent::Delivery::DeliveryQuery
128
- def taxonomy(code_name)
129
- DeliveryQuery.new project_id: @project_id,
130
- secure_key: @secure_key,
131
- code_name: code_name,
132
- query_type: QUERY_TYPE_TAXONOMIES,
133
- with_retry_policy: @with_retry_policy
134
- end
135
-
136
- # Return a single element of a content type
137
- #
138
- # * *Args*:
139
- # - *content_type* (+string+) The code name of the content type containing the element
140
- # - *element* (+string+) The code name of the desired element
141
- #
142
- # * *Returns*:
143
- # - Kentico::Kontent::Delivery::DeliveryQuery
144
- def element(content_type, element)
145
- DeliveryQuery.new project_id: @project_id,
146
- secure_key: @secure_key,
147
- code_name: element,
148
- content_type: content_type,
149
- query_type: QUERY_TYPE_ELEMENT,
150
- with_retry_policy: @with_retry_policy
151
- end
152
- end
153
- end
154
- end
155
- end
1
+ require 'delivery/client/delivery_query'
2
+ require 'delivery/responses/delivery_item_listing_response'
3
+ require 'delivery/responses/delivery_item_response'
4
+ require 'json'
5
+
6
+ module Kentico
7
+ module Kontent
8
+ module Delivery
9
+ QUERY_TYPE_TYPES = 'QUERY_TYPE_TYPES'.freeze
10
+ QUERY_TYPE_ITEMS = 'QUERY_TYPE_ITEMS'.freeze
11
+ QUERY_TYPE_TAXONOMIES = 'QUERY_TYPE_TAXONOMIES'.freeze
12
+ QUERY_TYPE_ELEMENT = 'QUERY_TYPE_ELEMENT'.freeze
13
+
14
+ # Executes requests against the Kentico Kontent Delivery API.
15
+ class DeliveryClient
16
+ attr_accessor :use_preview
17
+
18
+ # Constructor. Accepts a hash with the options for client.
19
+ #
20
+ # * *Args*:
21
+ # - *config* (+Hash+) May contain the following keys:
22
+ # - project_id (+string+) _required_
23
+ # - preview_key (+string+)
24
+ # - secure_key (+string+)
25
+ # - content_link_url_resolver ( Kentico::Kontent::Delivery::Resolvers::ContentLinkResolver )
26
+ # - inline_content_item_resolver ( Kentico::Kontent::Delivery::Resolvers::InlineContentItemResolver )
27
+ # - with_retry_policy (+bool+)
28
+ def initialize(config)
29
+ @project_id = config.fetch(:project_id)
30
+ @preview_key = config.fetch(:preview_key, nil)
31
+ @secure_key = config.fetch(:secure_key, nil)
32
+ @content_link_url_resolver = config.fetch(:content_link_url_resolver, nil)
33
+ @inline_content_item_resolver = config.fetch(:inline_content_item_resolver, nil)
34
+ @with_retry_policy = config.fetch(:with_retry_policy, true)
35
+ self.use_preview = !@preview_key.nil?
36
+ end
37
+
38
+ # Return all content types of the project
39
+ #
40
+ # * *Returns*:
41
+ # - Kentico::Kontent::Delivery::DeliveryQuery
42
+ def types
43
+ DeliveryQuery.new project_id: @project_id,
44
+ secure_key: @secure_key,
45
+ query_type: QUERY_TYPE_TYPES,
46
+ with_retry_policy: @with_retry_policy
47
+ end
48
+
49
+ # Return a single content type of the project
50
+ #
51
+ # * *Args*:
52
+ # - *code_name* (+string+) Code name of the desired content type
53
+ #
54
+ # * *Returns*:
55
+ # - Kentico::Kontent::Delivery::DeliveryQuery
56
+ def type(code_name)
57
+ DeliveryQuery.new project_id: @project_id,
58
+ secure_key: @secure_key,
59
+ code_name: code_name,
60
+ query_type: QUERY_TYPE_TYPES,
61
+ with_retry_policy: @with_retry_policy
62
+ end
63
+
64
+ # Return all content items of the project
65
+ #
66
+ # * *Args*:
67
+ # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
68
+ #
69
+ # * *Returns*:
70
+ # - Kentico::Kontent::Delivery::DeliveryQuery
71
+ def items(query_parameters = [])
72
+ q = DeliveryQuery.new project_id: @project_id,
73
+ secure_key: @secure_key,
74
+ qp: query_parameters,
75
+ content_link_url_resolver: @content_link_url_resolver,
76
+ inline_content_item_resolver: @inline_content_item_resolver,
77
+ query_type: QUERY_TYPE_ITEMS,
78
+ with_retry_policy: @with_retry_policy
79
+ q.use_preview = use_preview
80
+ q.preview_key = @preview_key
81
+ q
82
+ end
83
+
84
+ # Return a single content item of the project
85
+ #
86
+ # * *Args*:
87
+ # - *code_name* (+string+) The code name of the desired content item
88
+ # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
89
+ #
90
+ # * *Returns*:
91
+ # - Kentico::Kontent::Delivery::DeliveryQuery
92
+ def item(code_name, query_parameters = [])
93
+ q = DeliveryQuery.new project_id: @project_id,
94
+ secure_key: @secure_key,
95
+ code_name: code_name,
96
+ qp: query_parameters,
97
+ content_link_url_resolver: @content_link_url_resolver,
98
+ inline_content_item_resolver: @inline_content_item_resolver,
99
+ query_type: QUERY_TYPE_ITEMS,
100
+ with_retry_policy: @with_retry_policy
101
+ q.use_preview = use_preview
102
+ q.preview_key = @preview_key
103
+ q
104
+ end
105
+
106
+ # Return all taxonomy groups of the project
107
+ #
108
+ # * *Args*:
109
+ # - *query_parameters* (+Array+) _optional_ One or more Kentico::Kontent::Delivery::QueryParameters::Filter objects. A single object will automatically be converted into an Array.
110
+ #
111
+ # * *Returns*:
112
+ # - Kentico::Kontent::Delivery::DeliveryQuery
113
+ def taxonomies(query_parameters = [])
114
+ DeliveryQuery.new project_id: @project_id,
115
+ secure_key: @secure_key,
116
+ qp: query_parameters,
117
+ query_type: QUERY_TYPE_TAXONOMIES,
118
+ with_retry_policy: @with_retry_policy
119
+ end
120
+
121
+ # Return a single taxonomy group of the project
122
+ #
123
+ # * *Args*:
124
+ # - *code_name* (+string+) The code name of the desired taxonomy group
125
+ #
126
+ # * *Returns*:
127
+ # - Kentico::Kontent::Delivery::DeliveryQuery
128
+ def taxonomy(code_name)
129
+ DeliveryQuery.new project_id: @project_id,
130
+ secure_key: @secure_key,
131
+ code_name: code_name,
132
+ query_type: QUERY_TYPE_TAXONOMIES,
133
+ with_retry_policy: @with_retry_policy
134
+ end
135
+
136
+ # Return a single element of a content type
137
+ #
138
+ # * *Args*:
139
+ # - *content_type* (+string+) The code name of the content type containing the element
140
+ # - *element* (+string+) The code name of the desired element
141
+ #
142
+ # * *Returns*:
143
+ # - Kentico::Kontent::Delivery::DeliveryQuery
144
+ def element(content_type, element)
145
+ DeliveryQuery.new project_id: @project_id,
146
+ secure_key: @secure_key,
147
+ code_name: element,
148
+ content_type: content_type,
149
+ query_type: QUERY_TYPE_ELEMENT,
150
+ with_retry_policy: @with_retry_policy
151
+ end
152
+ end
153
+ end
154
+ end
155
+ end