Class: Hanami::Config::Actions::ContentSecurityPolicy
- Inherits:
- 
      Object
      
        - Object
- Hanami::Config::Actions::ContentSecurityPolicy
 
- Defined in:
- lib/hanami/config/actions/content_security_policy.rb
Overview
Config for Content Security Policy in Hanami apps
Instance Method Summary collapse
- 
  
    
      #[](key)  ⇒ String, NilClass 
    
    
  
  
  
  
  
  
  
  
  
    Get a CSP setting. 
- 
  
    
      #[]=(key, value)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Set a CSP setting. 
- 
  
    
      #delete(key)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Deletes a CSP key. 
- 
  
    
      #initialize(&blk)  ⇒ ContentSecurityPolicy 
    
    
  
  
  
    constructor
  
  
  
  
  
  private
  
    A new instance of ContentSecurityPolicy. 
- #initialize_copy(original_object) ⇒ Object private
- #to_s ⇒ Object private
Constructor Details
#initialize(&blk) ⇒ ContentSecurityPolicy
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of ContentSecurityPolicy.
| 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 12 def initialize(&blk) @policy = { base_uri: "'self'", child_src: "'self'", connect_src: "'self'", default_src: "'none'", font_src: "'self'", form_action: "'self'", frame_ancestors: "'self'", frame_src: "'self'", img_src: "'self' https: data:", media_src: "'self'", object_src: "'none'", script_src: "'self'", style_src: "'self' 'unsafe-inline' https:" } blk&.(self) end | 
Instance Method Details
#[](key) ⇒ String, NilClass
Get a CSP setting
| 53 54 55 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 53 def [](key) @policy[key] end | 
#[]=(key, value) ⇒ Object
Set a CSP setting
| 78 79 80 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 78 def []=(key, value) @policy[key] = value end | 
#delete(key) ⇒ Object
Deletes a CSP key
| 95 96 97 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 95 def delete(key) @policy.delete(key) end | 
#initialize_copy(original_object) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
| 34 35 36 37 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 34 def initialize_copy(original_object) @policy = original_object.instance_variable_get(:@policy).dup super end | 
#to_s ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
| 101 102 103 104 105 | # File 'lib/hanami/config/actions/content_security_policy.rb', line 101 def to_s @policy.map do |key, value| "#{dasherize(key)} #{value}" end.join(";") end |