~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/auth_test/auth_test.cc

[patch 125/129] Merge patch for revision 1943 from InnoDB SVN:
revno: 1943
revision-id: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6207
parent: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6202
committer: vasil
timestamp: Fri 2009-11-20 08:19:14 +0000
message:
  branches/zip: Merge r6198:6206 from branches/5.1:
  
  (r6203 was skipped as it is already in branches/zip)
  
    ------------------------------------------------------------------------
    r6200 | vasil | 2009-11-19 12:14:23 +0200 (Thu, 19 Nov 2009) | 4 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1:
    
    White space fixup - indent under the opening (
    
    ------------------------------------------------------------------------
    r6203 | jyang | 2009-11-19 15:12:22 +0200 (Thu, 19 Nov 2009) | 8 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1: Use btr_free_root() instead of fseg_free() for
    the fix of bug #48469, because fseg_free() is not defined
    in the zip branch. And we could save one mini-trasaction started
    by fseg_free().
    
    Approved by Marko.
    
    
    ------------------------------------------------------------------------
    r6205 | jyang | 2009-11-20 07:55:48 +0200 (Fri, 20 Nov 2009) | 11 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Add a special case to handle the Duplicated Key error
    and return DB_ERROR instead. This is to avoid a possible SIGSEGV
    by mysql error handling re-entering the storage layer for dup key
    info without proper table handle.
    This is to prevent a server crash when error situation in bug
    #45961 "DDL on partitioned innodb tables leaves data dictionary
    in an inconsistent state" happens.
    
    rb://157 approved by Sunny Bains.
    
    
    ------------------------------------------------------------------------
    r6206 | jyang | 2009-11-20 09:38:43 +0200 (Fri, 20 Nov 2009) | 5 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Fix a minor code formating issue for 
    the parenthesis iplacement of the if condition in
    rename_table().
    
    
    ------------------------------------------------------------------------
modified:
  handler/ha_innodb.cc           2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fhandler%2Fha_innodb.cc
diff:
=== modified file 'handler/ha_innodb.cc'

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
18
 */
19
19
 
20
 
#include <config.h>
 
20
#include "config.h"
21
21
 
22
22
#include <string>
23
23
 
24
 
#include <drizzled/plugin/authentication.h>
25
 
#include <drizzled/identifier.h>
26
 
#include <drizzled/util/convert.h>
27
 
#include <drizzled/algorithm/sha1.h>
 
24
#include "drizzled/plugin/authentication.h"
 
25
#include "drizzled/security_context.h"
 
26
#include "drizzled/util/convert.h"
 
27
#include "drizzled/algorithm/sha1.h"
28
28
 
29
29
using namespace std;
30
30
using namespace drizzled;
42
42
    plugin::Authentication(name_arg)
43
43
  { }
44
44
 
45
 
  virtual bool authenticate(const identifier::User &sctx, const string &password)
 
45
  virtual bool authenticate(const SecurityContext &sctx, const string &password)
46
46
  {
47
47
    /* The "root" user always succeeds for drizzletest to get in. */
48
 
    if (sctx.username() == "root" && password.empty())
 
48
    if (sctx.getUser() == "root" && password.empty())
49
49
      return true;
50
50
 
51
51
    /* Any password succeeds. */
52
 
    if (sctx.username() == "password_ok" && !password.empty())
 
52
    if (sctx.getUser() == "password_ok" && !password.empty())
53
53
      return true;
54
54
 
55
55
    /* No password succeeds. */
56
 
    if (sctx.username() == "no_password_ok" && password.empty())
 
56
    if (sctx.getUser() == "no_password_ok" && password.empty())
57
57
      return true;
58
58
 
59
59
    /* Check if MySQL password scramble succeeds. */
60
 
    if (sctx.username() == "scramble_ok" &&
61
 
        sctx.getPasswordType() == identifier::User::MYSQL_HASH &&
 
60
    if (sctx.getUser() == "scramble_ok" &&
 
61
        sctx.getPasswordType() == SecurityContext::MYSQL_HASH &&
62
62
        sctx.getPasswordContext().size() == SHA1_DIGEST_LENGTH &&
63
63
        password.size() == SHA1_DIGEST_LENGTH)
64
64
    {