Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions lib/oktakit/client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
require 'oktakit/client/groups'
require 'oktakit/client/group_rules'
require 'oktakit/client/identity_providers'
require 'oktakit/client/policies'
require 'oktakit/client/policy_rules'
require 'oktakit/client/schemas'
require 'oktakit/client/templates'
require 'oktakit/client/users'
Expand All @@ -20,6 +22,8 @@ class Client
include Groups
include GroupRules
include IdentityProviders
include Policies
include PolicyRules
include Schemas
include Templates
include Users
Expand Down
81 changes: 81 additions & 0 deletions lib/oktakit/client/policies.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
module Oktakit
class Client
module Policies
# List Policies
#
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Array<Sawyer::Resource>] Array of Policies
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/listPolicies
# @example
# Oktakit.list_policies(query: {type: 'IDP_DISCOVERY'})
def list_policies(options = {})
get("/policies", options)
end

# Create a policy
#
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] The created Policy
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/createPolicy
# @example
# Oktakit.add_policy
def add_policy(options = {})
post("/policies", options)
end

# Retrieve a policy
#
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] Policy
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/getPolicy
# @example
# Oktakit.get_policy('id')
def get_policy(id, options = {})
get("/policies/#{id}", options)
end

# Update a policy
#
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] The updated Policy
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/replacePolicy
# @example
# Oktakit.update_policy('id', options)
def update_policy(id, options = {})
put("/policies/#{id}", options)
end

# Delete a policy
#
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return 204 No content
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/deletePolicy
# @example
# Oktakit.delete_policy('id', options)
def delete_policy(id, options = {})
delete("/policies/#{id}", options)
end

end
end
end
89 changes: 89 additions & 0 deletions lib/oktakit/client/policy_rules.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
module Oktakit
class Client
module PolicyRules
# List Policy Rules
#
# @param policy_id [string] Policy ID
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Array<Sawyer::Resource>] Array of Policy Rules
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/listPolicyRules
# @example
# Oktakit.list_policy_rules('policy_id')
def list_policy_rules(policy_id, options = {})
get("/policies/#{policy_id}/rules", options)
end

# Create Policy Rule
#
# @param policy_id [string] Policy ID
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] The created Policy Rule
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/createPolicyRule
# @example
# Oktakit.add_policy_rule('policy_id', {})
def add_policy_rule(policy_id, options = {})
post("/policies/#{policy_id}/rules", options)
end

# Get Policy Rule
#
# @param policy_id [string] Policy ID
# @param rule_id [string] Rule ID
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] Policy Rule
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/getPolicyRule
# @example
# Oktakit.get_policy_rule('policy_id', 'rule_id', {})
def get_policy_rule(policy_id, rule_id, options = {})
get("/policies/#{policy_id}/rules/#{rule_id}", options)
end

# Update Policy Rule
#
# @param policy_id [string] Policy ID
# @param rule_id [string] Rule ID
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return [Sawyer::Resource] Updated policy rule
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/replacePolicyRule
# @example
# Oktakit.update_policy_rule('policy_id', 'rule_id', {})
def update_policy_rule(policy_id, rule_id, options = {})
put("/policies/#{policy_id}/rules/#{rule_id}", options)
end

# Delete a Policy Rule
#
# @param policy_id [string] Policy ID
# @param rule_id [string] Rule ID
# @param options[:query] [Hash] Optional. Query params for request
# @param options[:headers] [Hash] Optional. Header params for the request.
# @param options[:accept] [String] Optional. The content type to accept. Default application/json
# @param options[:content_type] [String] Optional. The content type for the request. Default application/json
# @param options [Hash] Optional. Body params for request.
# @return 204 No content
# @see https://developer.okta.com/docs/api/openapi/okta-management/management/tag/Policy/#tag/Policy/operation/deletePolicyRule
# @example
# Oktakit.delete_policy_rule('policy_id', 'rule_id', {})
def delete_policy_rule(policy_id, rule_id, options = {})
delete("/policies/#{policy_id}/rules/#{rule_id}", options)
end

end
end
end
67 changes: 67 additions & 0 deletions spec/cassettes/add_policy.yml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

68 changes: 68 additions & 0 deletions spec/cassettes/add_policy_rule.yml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

67 changes: 67 additions & 0 deletions spec/cassettes/delete_policy.yml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading