Class: Contentful::Management::Client
- Inherits:
-
Object
- Object
- Contentful::Management::Client
- Defined in:
- lib/contentful/management/client.rb
Overview
Client for interacting with the Contentful Management API
Constant Summary collapse
- DEFAULT_CONFIGURATION =
Default configuration for Contentful::Management::Client
{ api_url: 'api.contentful.com', uploads_url: 'upload.contentful.com', api_version: '1', secure: true, default_locale: 'en-US', gzip_encoded: false, logger: false, log_level: Logger::INFO, raise_errors: false, dynamic_entries: {}, disable_content_type_caching: false, proxy_host: nil, proxy_port: nil, proxy_username: nil, proxy_password: nil, max_rate_limit_retries: 1, max_rate_limit_wait: 60, application_name: nil, application_version: nil, integration_name: nil, integration_version: nil }.freeze
- RATE_LIMIT_RESET_HEADER_KEY =
Rate Limit Reset Header Key
'x-contentful-ratelimit-reset'.freeze
Instance Attribute Summary collapse
-
#access_token ⇒ Object
readonly
Returns the value of attribute access_token.
-
#configuration ⇒ Object
readonly
Returns the value of attribute configuration.
-
#content_type_id ⇒ Object
Returns the value of attribute content_type_id.
-
#dynamic_entry_cache ⇒ Object
Returns the value of attribute dynamic_entry_cache.
-
#logger ⇒ Object
readonly
Returns the value of attribute logger.
-
#organization_id ⇒ Object
Returns the value of attribute organization_id.
-
#version ⇒ Object
Returns the value of attribute version.
Instance Method Summary collapse
-
#api_keys(space_id) ⇒ Contentful::Management::ClientApiKeyMethodsFactory
Allows manipulation of api keys in context of the current client Allows listing all api keys for client, creating new and finding one by ID.
-
#api_usage(organization_id) ⇒ Contentful::Management::ClientApiUsageMethodsFactory
Allows viewing of api usage in context of the current client Allows listing all api usage for client.
-
#assets(space_id, environment_id) ⇒ Contentful::Management::ClientAssetMethodsFactory
Allows manipulation of assets in context of the current client Allows listing all assets for client, creating new and finding one by ID.
-
#content_type_snapshots(space_id, environment_id) ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of content type snapshots in context of the current client Allows listing all content type snapshots for client and finding one by ID.
-
#content_types(space_id, environment_id) ⇒ Contentful::Management::ClientContentTypeMethodsFactory
Allows manipulation of content types in context of the current client Allows listing all content types for client, creating new and finding one by ID.
-
#editor_interfaces(space_id, environment_id, content_type_id) ⇒ Contentful::Management::ClientEditorInterfaceMethodsFactory
Allows manipulation of editor interfaces in context of the current client Allows listing all editor interfaces for client and finding one by content type.
-
#entries(space_id, environment_id) ⇒ Contentful::Management::ClientEntryMethodsFactory
Allows manipulation of entries in context of the current client Allows listing all entries for client, creating new and finding one by ID.
-
#entry_snapshots(space_id, environment_id) ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of entry snapshots in context of the current client Allows listing all entry snapshots for client and finding one by ID.
-
#environments(space_id) ⇒ Contentful::Management::ClientEnvironmentMethodsFactory
Allows manipulation of environments in context of the current client Allows listing all environments for client, creating new and finding one by ID.
-
#http_send(type, url, params, headers, proxy) ⇒ HTTP::Response
HTTP Helper Abtracts the Proxy/No-Proxy logic.
-
#initialize(access_token = nil, configuration = {}) ⇒ Client
constructor
A new instance of Client.
-
#locales(space_id, environment_id) ⇒ Contentful::Management::ClientLocaleMethodsFactory
Allows manipulation of locales in context of the current client Allows listing all locales for client, creating new and finding one by ID.
-
#organizations ⇒ Contentful::Management::ClientOrganizationMethodsFactory
Allows viewing of organizations in context of the current client Allows listing all organizations for client.
-
#personal_access_tokens ⇒ Contentful::Management::ClientPersonalAccessTokenMethodsFactory
Allows manipulation of personal access tokens in context of the current client Allows listing all personal access tokens for client, creating new and finding one by ID.
-
#preview_api_keys(space_id) ⇒ Contentful::Management::ClientPreviewApiKeyMethodsFactory
Allows manipulation of api keys in context of the current client Allows listing all preview api keys for client and finding one by ID.
-
#proxy_send(type, url, params, headers, proxy) ⇒ HTTP::Response
Proxy Helper.
-
#roles(space_id) ⇒ Contentful::Management::ClientRoleMethodsFactory
Allows manipulation of roles in context of the current client Allows listing all roles for client, creating new and finding one by ID.
-
#snapshots(space_id, environment_id, resource_type = 'entries') ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of snapshots in context of the current client Allows listing all snapshots for client and finding one by ID.
-
#space_memberships(space_id) ⇒ Contentful::Management::ClientSpaceMembershipMethodsFactory
Allows manipulation of space memberships in context of the current client Allows listing all space memberships for client, creating new and finding one by ID.
-
#spaces ⇒ Contentful::Management::ClientSpaceMethodsFactory
Allows manipulation of spaces in context of the current client Allows listing all spaces for client, creating new and finding one by ID.
-
#ui_extensions(space_id, environment_id) ⇒ Contentful::Management::ClientUIExtensionMethodsFactory
Allows manipulation of UI extensions in context of the current client Allows listing all UI extensions for client, creating new and finding one by ID.
-
#uploads(space_id) ⇒ Contentful::Management::ClientUploadMethodsFactory
Allows manipulation of uploads in context of the current client Allows creating new and finding uploads by ID.
-
#usage_periods(organization_id) ⇒ Contentful::Management::ClientUsagePeriodMethodsFactory
Allows viewing of usage periods in context of the current client Allows listing all usage periods for client.
-
#users ⇒ Contentful::Management::ClientUserMethodsFactory
Allows viewing of users in context of the current client Allows listing all users for client.
-
#webhook_calls(space_id, webhook_id) ⇒ Contentful::Management::ClientWebhookCallMethodsFactory
Allows manipulation of webhook calls in context of the current client Allows listing all webhook call details for client and finding one by ID.
-
#webhook_health(space_id) ⇒ Contentful::Management::ClientWebhookHealthMethodsFactory
Allows manipulation of webhook health in context of the current client Allows listing all webhook health details for client and finding one by ID.
-
#webhooks(space_id) ⇒ Contentful::Management::ClientWebhookMethodsFactory
Allows manipulation of webhooks in context of the current client Allows listing all webhooks for client, creating new and finding one by ID.
Constructor Details
#initialize(access_token = nil, configuration = {}) ⇒ Client
Returns a new instance of Client.
91 92 93 94 95 96 97 98 |
# File 'lib/contentful/management/client.rb', line 91 def initialize(access_token = nil, configuration = {}) @configuration = default_configuration.merge(configuration) setup_logger @access_token = access_token @dynamic_entry_cache = {} Thread.current[:client] = self update_all_dynamic_entry_cache! end |
Instance Attribute Details
#access_token ⇒ Object (readonly)
Returns the value of attribute access_token.
41 42 43 |
# File 'lib/contentful/management/client.rb', line 41 def access_token @access_token end |
#configuration ⇒ Object (readonly)
Returns the value of attribute configuration.
41 42 43 |
# File 'lib/contentful/management/client.rb', line 41 def configuration @configuration end |
#content_type_id ⇒ Object
Returns the value of attribute content_type_id.
42 43 44 |
# File 'lib/contentful/management/client.rb', line 42 def content_type_id @content_type_id end |
#dynamic_entry_cache ⇒ Object
Returns the value of attribute dynamic_entry_cache.
42 43 44 |
# File 'lib/contentful/management/client.rb', line 42 def dynamic_entry_cache @dynamic_entry_cache end |
#logger ⇒ Object (readonly)
Returns the value of attribute logger.
41 42 43 |
# File 'lib/contentful/management/client.rb', line 41 def logger @logger end |
#organization_id ⇒ Object
Returns the value of attribute organization_id.
42 43 44 |
# File 'lib/contentful/management/client.rb', line 42 def organization_id @organization_id end |
#version ⇒ Object
Returns the value of attribute version.
42 43 44 |
# File 'lib/contentful/management/client.rb', line 42 def version @version end |
Instance Method Details
#api_keys(space_id) ⇒ Contentful::Management::ClientApiKeyMethodsFactory
Allows manipulation of api keys in context of the current client Allows listing all api keys for client, creating new and finding one by ID.
168 169 170 |
# File 'lib/contentful/management/client.rb', line 168 def api_keys(space_id) ClientApiKeyMethodsFactory.new(self, space_id) end |
#api_usage(organization_id) ⇒ Contentful::Management::ClientApiUsageMethodsFactory
Allows viewing of api usage in context of the current client Allows listing all api usage for client.
150 151 152 |
# File 'lib/contentful/management/client.rb', line 150 def api_usage(organization_id) ClientApiUsageMethodsFactory.new(self, organization_id) end |
#assets(space_id, environment_id) ⇒ Contentful::Management::ClientAssetMethodsFactory
Allows manipulation of assets in context of the current client Allows listing all assets for client, creating new and finding one by ID.
195 196 197 |
# File 'lib/contentful/management/client.rb', line 195 def assets(space_id, environment_id) ClientAssetMethodsFactory.new(self, space_id, environment_id) end |
#content_type_snapshots(space_id, environment_id) ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of content type snapshots in context of the current client Allows listing all content type snapshots for client and finding one by ID.
312 313 314 |
# File 'lib/contentful/management/client.rb', line 312 def content_type_snapshots(space_id, environment_id) ClientSnapshotMethodsFactory.new(self, space_id, environment_id, 'content_types') end |
#content_types(space_id, environment_id) ⇒ Contentful::Management::ClientContentTypeMethodsFactory
Allows manipulation of content types in context of the current client Allows listing all content types for client, creating new and finding one by ID.
204 205 206 |
# File 'lib/contentful/management/client.rb', line 204 def content_types(space_id, environment_id) ClientContentTypeMethodsFactory.new(self, space_id, environment_id) end |
#editor_interfaces(space_id, environment_id, content_type_id) ⇒ Contentful::Management::ClientEditorInterfaceMethodsFactory
Allows manipulation of editor interfaces in context of the current client Allows listing all editor interfaces for client and finding one by content type.
249 250 251 |
# File 'lib/contentful/management/client.rb', line 249 def editor_interfaces(space_id, environment_id, content_type_id) ClientEditorInterfaceMethodsFactory.new(self, space_id, environment_id, content_type_id) end |
#entries(space_id, environment_id) ⇒ Contentful::Management::ClientEntryMethodsFactory
Allows manipulation of entries in context of the current client Allows listing all entries for client, creating new and finding one by ID.
213 214 215 |
# File 'lib/contentful/management/client.rb', line 213 def entries(space_id, environment_id) ClientEntryMethodsFactory.new(self, space_id, environment_id) end |
#entry_snapshots(space_id, environment_id) ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of entry snapshots in context of the current client Allows listing all entry snapshots for client and finding one by ID.
303 304 305 |
# File 'lib/contentful/management/client.rb', line 303 def entry_snapshots(space_id, environment_id) ClientSnapshotMethodsFactory.new(self, space_id, environment_id, 'entries') end |
#environments(space_id) ⇒ Contentful::Management::ClientEnvironmentMethodsFactory
Allows manipulation of environments in context of the current client Allows listing all environments for client, creating new and finding one by ID.
114 115 116 |
# File 'lib/contentful/management/client.rb', line 114 def environments(space_id) ClientEnvironmentMethodsFactory.new(self, space_id) end |
#http_send(type, url, params, headers, proxy) ⇒ HTTP::Response
HTTP Helper Abtracts the Proxy/No-Proxy logic
494 495 496 497 |
# File 'lib/contentful/management/client.rb', line 494 def http_send(type, url, params, headers, proxy) return proxy_send(type, url, params, headers, proxy) unless proxy[:host].nil? HTTP[headers].public_send(type, url, params) end |
#locales(space_id, environment_id) ⇒ Contentful::Management::ClientLocaleMethodsFactory
Allows manipulation of locales in context of the current client Allows listing all locales for client, creating new and finding one by ID.
222 223 224 |
# File 'lib/contentful/management/client.rb', line 222 def locales(space_id, environment_id) ClientLocaleMethodsFactory.new(self, space_id, environment_id) end |
#organizations ⇒ Contentful::Management::ClientOrganizationMethodsFactory
Allows viewing of organizations in context of the current client Allows listing all organizations for client.
132 133 134 |
# File 'lib/contentful/management/client.rb', line 132 def organizations ClientOrganizationMethodsFactory.new(self) end |
#personal_access_tokens ⇒ Contentful::Management::ClientPersonalAccessTokenMethodsFactory
Allows manipulation of personal access tokens in context of the current client Allows listing all personal access tokens for client, creating new and finding one by ID.
186 187 188 |
# File 'lib/contentful/management/client.rb', line 186 def personal_access_tokens ClientPersonalAccessTokenMethodsFactory.new(self) end |
#preview_api_keys(space_id) ⇒ Contentful::Management::ClientPreviewApiKeyMethodsFactory
Allows manipulation of api keys in context of the current client Allows listing all preview api keys for client and finding one by ID.
177 178 179 |
# File 'lib/contentful/management/client.rb', line 177 def preview_api_keys(space_id) ClientPreviewApiKeyMethodsFactory.new(self, space_id) end |
#proxy_send(type, url, params, headers, proxy) ⇒ HTTP::Response
Proxy Helper
475 476 477 478 479 480 481 482 |
# File 'lib/contentful/management/client.rb', line 475 def proxy_send(type, url, params, headers, proxy) HTTP[headers].via( proxy[:host], proxy[:port], proxy[:username], proxy[:password] ).public_send(type, url, params) end |
#roles(space_id) ⇒ Contentful::Management::ClientRoleMethodsFactory
Allows manipulation of roles in context of the current client Allows listing all roles for client, creating new and finding one by ID.
231 232 233 |
# File 'lib/contentful/management/client.rb', line 231 def roles(space_id) ClientRoleMethodsFactory.new(self, space_id) end |
#snapshots(space_id, environment_id, resource_type = 'entries') ⇒ Contentful::Management::ClientSnapshotMethodsFactory
Allows manipulation of snapshots in context of the current client Allows listing all snapshots for client and finding one by ID.
294 295 296 |
# File 'lib/contentful/management/client.rb', line 294 def snapshots(space_id, environment_id, resource_type = 'entries') ClientSnapshotMethodsFactory.new(self, space_id, environment_id, resource_type) end |
#space_memberships(space_id) ⇒ Contentful::Management::ClientSpaceMembershipMethodsFactory
Allows manipulation of space memberships in context of the current client Allows listing all space memberships for client, creating new and finding one by ID.
123 124 125 |
# File 'lib/contentful/management/client.rb', line 123 def space_memberships(space_id) ClientSpaceMembershipMethodsFactory.new(self, space_id) end |
#spaces ⇒ Contentful::Management::ClientSpaceMethodsFactory
Allows manipulation of spaces in context of the current client Allows listing all spaces for client, creating new and finding one by ID.
105 106 107 |
# File 'lib/contentful/management/client.rb', line 105 def spaces ClientSpaceMethodsFactory.new(self) end |
#ui_extensions(space_id, environment_id) ⇒ Contentful::Management::ClientUIExtensionMethodsFactory
Allows manipulation of UI extensions in context of the current client Allows listing all UI extensions for client, creating new and finding one by ID.
240 241 242 |
# File 'lib/contentful/management/client.rb', line 240 def ui_extensions(space_id, environment_id) ClientUIExtensionMethodsFactory.new(self, space_id, environment_id) end |
#uploads(space_id) ⇒ Contentful::Management::ClientUploadMethodsFactory
Allows manipulation of uploads in context of the current client Allows creating new and finding uploads by ID.
285 286 287 |
# File 'lib/contentful/management/client.rb', line 285 def uploads(space_id) ClientUploadMethodsFactory.new(self, space_id) end |
#usage_periods(organization_id) ⇒ Contentful::Management::ClientUsagePeriodMethodsFactory
Allows viewing of usage periods in context of the current client Allows listing all usage periods for client.
141 142 143 |
# File 'lib/contentful/management/client.rb', line 141 def usage_periods(organization_id) ClientUsagePeriodMethodsFactory.new(self, organization_id) end |
#users ⇒ Contentful::Management::ClientUserMethodsFactory
Allows viewing of users in context of the current client Allows listing all users for client.
159 160 161 |
# File 'lib/contentful/management/client.rb', line 159 def users ClientUserMethodsFactory.new(self) end |
#webhook_calls(space_id, webhook_id) ⇒ Contentful::Management::ClientWebhookCallMethodsFactory
Allows manipulation of webhook calls in context of the current client Allows listing all webhook call details for client and finding one by ID.
267 268 269 |
# File 'lib/contentful/management/client.rb', line 267 def webhook_calls(space_id, webhook_id) ClientWebhookCallMethodsFactory.new(self, space_id, webhook_id) end |
#webhook_health(space_id) ⇒ Contentful::Management::ClientWebhookHealthMethodsFactory
Allows manipulation of webhook health in context of the current client Allows listing all webhook health details for client and finding one by ID.
276 277 278 |
# File 'lib/contentful/management/client.rb', line 276 def webhook_health(space_id) ClientWebhookHealthMethodsFactory.new(self, space_id) end |
#webhooks(space_id) ⇒ Contentful::Management::ClientWebhookMethodsFactory
Allows manipulation of webhooks in context of the current client Allows listing all webhooks for client, creating new and finding one by ID.
258 259 260 |
# File 'lib/contentful/management/client.rb', line 258 def webhooks(space_id) ClientWebhookMethodsFactory.new(self, space_id) end |