CVE-2026-4117 MEDIUM

CVE-2026-4117: CalJ <= 1.5 - Authenticated (Subscriber+) Arbitrary Settings Modification via 'save-obtained-key' Action

Vendor Calj
Product CalJ Shabbat Times
Weakness CWE-862 · Missing authorization
Published April 22, 2026
Last update April 22, 2026

CVSS base score

5.3/10
Attack vector Network
Attack complexity Low
Privileges required None
User interaction None
Confidentiality None
Integrity Low

CVSS vector

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N

What the vulnerability does

01Description

The CalJ plugin for WordPress is vulnerable to Missing Authorization in all versions up to, and including, 1.5. This is due to a missing capability check in the CalJSettingsPage class constructor, which processes the 'save-obtained-key' operation directly from POST data without verifying that the requesting user has the 'manage_options' capability, and without any nonce verification. The plugin bootstrap file (calj.php) instantiates CalJSettingsPage whenever is_admin() returns true, which is the case for any authenticated user making requests to wp-admin URLs (including admin-ajax.php). This makes it possible for authenticated attackers, with Subscriber-level access and above, to modify the plugin's API key setting and clear the Shabbat cache, effectively taking control of the plugin's API integration.

Explanation of Vulnerability in Simple Terms

02Summary

CalJ Shabbat Times versions 1.5 and earlier lack proper authorization checks, allowing unauthenticated attackers to modify data via the network. The vulnerability requires no user interaction and affects data integrity. Site administrators should update to a version newer than 1.5 when available.

What an attacker can do

03Attacker Capabilities

Modify application data without authentication or permission.

Potential impact on your site

04Site Impact

Unauthorized users can alter Shabbat Times data, potentially disrupting service accuracy and user trust.

Conditions required to exploit

05Prerequisites

Network access to the application; no authentication required.

Key dates

06Disclosure timeline

April 22, 2026 CVE published
April 22, 2026 Record updated