~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/statement/create_schema.cc

  • Committer: Brian Aker
  • Date: 2010-05-18 22:31:57 UTC
  • mto: This revision was merged to the branch mainline in revision 1540.
  • Revision ID: brian@gaz-20100518223157-k0i4yxv6t03yrwyk
JoinCache rename.

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
#include <drizzled/session.h>
24
24
#include <drizzled/statement/create_schema.h>
25
25
#include <drizzled/db.h>
26
 
#include <drizzled/plugin/event_observer.h>
27
 
#include <drizzled/message.h>
28
26
 
29
27
#include <string>
30
28
 
44
42
  }
45
43
 
46
44
  SchemaIdentifier schema_identifier(string(session->lex->name.str, session->lex->name.length));
47
 
  if (not check(schema_identifier))
 
45
  if (not check_db_name(schema_identifier))
 
46
  {
 
47
    my_error(ER_WRONG_DB_NAME, MYF(0), schema_identifier.getSQLPath().c_str());
48
48
    return false;
49
 
 
50
 
  drizzled::message::init(schema_message, session->lex->name.str);
51
 
 
52
 
  bool res = false;
53
 
  std::string path;
54
 
  schema_identifier.getSQLPath(path);
55
 
 
56
 
  if (unlikely(plugin::EventObserver::beforeCreateDatabase(*session, path)))
57
 
  {
58
 
    my_error(ER_EVENT_OBSERVER_PLUGIN, MYF(0), path.c_str());
59
 
  }
60
 
  else
61
 
  {
62
 
    res= mysql_create_db(session, schema_message, is_if_not_exists);
63
 
    if (unlikely(plugin::EventObserver::afterCreateDatabase(*session, path, res)))
64
 
    {
65
 
      my_error(ER_EVENT_OBSERVER_PLUGIN, MYF(0), path.c_str());
66
 
      res = false;
67
 
    }
68
 
 
69
 
  }
70
 
 
 
49
  }
 
50
 
 
51
  schema_message.set_name(session->lex->name.str);
 
52
  schema_message.mutable_engine()->set_name(std::string("filesystem")); // For the moment we have only one.
 
53
  if (not schema_message.has_collation())
 
54
  {
 
55
    schema_message.set_collation(default_charset_info->name);
 
56
  }
 
57
 
 
58
  bool res= mysql_create_db(session, schema_message, is_if_not_exists);
71
59
  return not res;
72
60
}
73
61
 
74
 
bool statement::CreateSchema::check(const SchemaIdentifier &identifier)
75
 
{
76
 
  if (not identifier.isValid())
77
 
    return false;
78
 
 
79
 
  if (not plugin::Authorization::isAuthorized(getSession()->getSecurityContext(), identifier))
80
 
    return false;
81
 
 
82
 
  if (not is_if_not_exists)
83
 
  {
84
 
    if (plugin::StorageEngine::doesSchemaExist(identifier))
85
 
    {
86
 
      std::string name;
87
 
 
88
 
      identifier.getSQLPath(name);
89
 
      my_error(ER_DB_CREATE_EXISTS, MYF(0), name.c_str());
90
 
 
91
 
      return false;
92
 
    }
93
 
  }
94
 
 
95
 
  return true;
96
 
}
97
 
 
98
62
// We don't actually test anything at this point, we assume it is all bad.
99
63
bool statement::CreateSchema::validateSchemaOptions()
100
64
{