Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:73329 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 81921 invoked from network); 20 Mar 2014 09:26:17 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 20 Mar 2014 09:26:17 -0000 Authentication-Results: pb1.pair.com smtp.mail=narf@devilix.net; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=narf@devilix.net; sender-id=pass Received-SPF: pass (pb1.pair.com: domain devilix.net designates 209.85.160.173 as permitted sender) X-PHP-List-Original-Sender: narf@devilix.net X-Host-Fingerprint: 209.85.160.173 mail-yk0-f173.google.com Received: from [209.85.160.173] ([209.85.160.173:52320] helo=mail-yk0-f173.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 09/68-33112-834BA235 for ; Thu, 20 Mar 2014 04:26:17 -0500 Received: by mail-yk0-f173.google.com with SMTP id 10so1521035ykt.4 for ; Thu, 20 Mar 2014 02:26:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=devilix.net; s=google; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; bh=t51j5nb/0oWnPDK4QNqo1wwl28a3s9N/znJKlhyaEOM=; b=vmLkfW1MANNsHPCQZdKiBTdLjCSq17CFkXnp/sq2h2CZyzduqtFpcsJYASmZQdpKfo OYg7uVJpNUWjtlhJTxhfk2agylrj8s0EWKeeU8TbuoPxXxy1KE7tQ6bMFm1J/5KrSsHZ eiyJ/oXXMQd0buhER3AdRd2Ihvi6vkdnss0RA= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc:content-type; bh=t51j5nb/0oWnPDK4QNqo1wwl28a3s9N/znJKlhyaEOM=; b=Cc180l8+HrSMKcM4wAGg/m9/WXxC/XzL5bHF66fb9JLzXI5X5TCk9gPQDst/zeg54P F9Q/AnvpLr/9RCMSPNIJU9SXgsCjqTidaQ5QSJjM64RTi39dsQYkKj0LRIAAbH72XS3W itthwWGzh1JeAKXtatttMjEhWVkbO33cl5bCAxKYNs9laQf5XfDl2dwtyjtufqpeSQqL vc2XYFVl+KzQhShMrymLp2uNN9pJ5GTGTM3R5EYXN/5/XcGsAgN3UVU2qmhCK9/eeU9d v9UbK9QgyZmVnQa909OM/UWojOL/4Nvhlerm22dSiYFNkZWrK0A8Yo+2Yg24znLU6dDU vr6w== X-Gm-Message-State: ALoCoQm8Fj5+8kX/uYYfcAxhkXcAV2oo/f5RVO/QJpANmxzrMQJv9ghy4wXM2Xj/VXv8cGCj0u8G MIME-Version: 1.0 X-Received: by 10.236.175.161 with SMTP id z21mr18001549yhl.80.1395307573697; Thu, 20 Mar 2014 02:26:13 -0700 (PDT) Received: by 10.170.188.139 with HTTP; Thu, 20 Mar 2014 02:26:13 -0700 (PDT) In-Reply-To: References: <20140319080229.GA83863@mail> <20140319111131.GB83863@mail> <20140320082346.GA61204@mail> <20140320091326.GA65574@mail> Date: Thu, 20 Mar 2014 11:26:13 +0200 Message-ID: To: Yasuo Ohgaki Cc: Mateusz Kocielski , "internals@lists.php.net" Content-Type: text/plain; charset=UTF-8 Subject: Re: [PHP-DEV] [RFC] [Discussion] Secure session_regenerate_id() From: narf@devilix.net (Andrey Andreev) Hi, >> Consider following scenario: >> >> 1. session_regenerate_id(..) is called >> 2. request to /update_session with old session id is done (some key-value >> in >> session is changed) - with your change this request will succeed >> --- from here user uses only new session - >> 3. updated key-value is missing in new session >> >> (same scenario can be triggered now if old session is not deleted) > > > This race condition will not change with or without my proposal. Which is another reason to leave this to user code: ajax_safe_regenerate_id($delete = TRUE) { if ( ! empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) === 'xmlhttprequest') { return FALSE; } return session_regenerate_id($delete); } Cheers, Andrey.