• CVE-2022-31163

发布时间: 2024年4月12日

修改时间: 2024年6月13日

概要

TZInfo is a Ruby library that provides access to time zone data and allows times to be converted using time zone rules. Versions prior to 0.36.1, as well as those prior to 1.2.10 when used with the Ruby data source tzinfo-data, are vulnerable to relative path traversal. With the Ruby data source, time zones are defined in Ruby files. There is one file per time zone. Time zone files are loaded with `require` on demand. In the affected versions, `TZInfo::Timezone.get` fails to validate time zone identifiers correctly, allowing a new line character within the identifier. With Ruby version 1.9.3 and later, `TZInfo::Timezone.get` can be made to load unintended files with `require`, executing them within the Ruby process. Versions 0.3.61 and 1.2.10 include fixes to correctly validate time zone identifiers. Versions 2.0.0 and later are not vulnerable. Version 0.3.61 can still load arbitrary files from the Ruby load path if their name follows the rules for a valid time zone identifier and the file has a prefix of `tzinfo/definition` within a directory in the load path. Applications should ensure that untrusted files are not placed in a directory on the load path. As a workaround, the time zone identifier can be validated before passing to `TZInfo::Timezone.get` by ensuring it matches the regular expression ` A[A-Za-z0-9+ -_]+(?: /[A-Za-z0-9+ -_]+)* z`.

CVSS v3 指标

NVD openEuler
CVSS评分 8.1 8.1
Attack Vector Network Network
Attack Complexity High High
Privileges Required None None
User Interaction None None
Scope Unchanged Unchanged
Confidentiality High High
Integrity High High
Availability High High

安全公告

公告名 概要 发布时间
KylinSec-SA-2024-3150 rubygem-tzinfo security update 2024年4月12日

影响产品

产品 状态
KY3.4-4A rubygem-tzinfo Fixed
KY3.4-5A rubygem-tzinfo Fixed
KY3.5.1 rubygem-tzinfo Unaffected
KY3.5.2 rubygem-tzinfo Unaffected
V6 rubygem-tzinfo Unaffected