Este producto no es compatible con el sitio Datadog seleccionado. ().
Esta página aún no está disponible en español. Estamos trabajando en su traducción.
Si tienes alguna pregunta o comentario sobre nuestro actual proyecto de traducción, no dudes en ponerte en contacto con nosotros.

Metadata

ID: ruby-security/avoid-clear-sensitive-info

Language: Ruby

Severity: Notice

Category: Security

Description

This rule highlights the importance of avoiding the storage of sensitive information, such as passwords, directly within objects or attributes. Storing sensitive data insecurely can lead to accidental exposure, especially if the data is logged, serialized, or accessed without proper safeguards.

Sensitive information often requires special handling, including encryption, secure storage mechanisms, or avoiding retention altogether. By not storing sensitive data in plain attributes, you reduce the risk of leaks and improve the overall security posture of your application.

To comply with this rule, avoid defining attribute accessors for sensitive fields like passwords. Instead, consider using secure authentication libraries or mechanisms that handle sensitive data safely. For example, store only hashed versions of passwords or use dedicated services for authentication rather than raw password storage in objects.

Non-Compliant Code Examples

class User
  attr_accessor :name
  attr_accessor :password

  def initialize(name, password)
    self.name = name
    self.password = password
  end

  def update_name(new_password)
    self.password = new_password
  end
end

Compliant Code Examples

class User
  attr_accessor :name

  def initialize(name)
    self.name = name  # using self to call the setter method
  end

  def update_name(new_name)
    self.name = new_name  # also uses the setter method
  end
end
https://static.datadoghq.com/static/images/logos/github_avatar.svg https://static.datadoghq.com/static/images/logos/vscode_avatar.svg jetbrains

Integraciones sin problemas. Prueba Datadog Code Security