function AutoSequelize(database, username, password, options) { if (options && options.dialect === 'sqlite' && ! options.storage) options.storage = database; if (database instanceof Sequelize) { this.sequelize = database; } else { this.sequelize = new Sequelize(database, username, password, options || {}); } this.queryInterface = this.sequelize.getQueryInterface(); this.tables = {}; this.foreignKeys = {}; this.dialect = dialects[this.sequelize.options.dialect]; this.options = _.extend({ global: 'Sequelize', local: 'sequelize', spaces: false, indentation: 1, directory: './models', additional: {}, freezeTableName: true }, options || {}); }
n/a
function escape(val, timeZone, dialect, format) { var prependN = false; if (val === undefined || val === null) { return 'NULL'; } switch (typeof val) { case 'boolean': // SQLite doesn't have true/false support. MySQL aliases true/false to 1/0 // for us. Postgres actually has a boolean type with true/false literals, // but sequelize doesn't use it yet. if (dialect === 'sqlite' || dialect === 'mssql') { return +!!val; } return '' + !!val; case 'number': return val + ''; case 'string': // In mssql, prepend N to all quoted vals which are originally a string (for // unicode compatibility) prependN = dialect === 'mssql'; break; } if (val instanceof Date) { val = dataTypes[dialect].DATE.prototype.stringify(val, { timezone: timeZone }); } if (Buffer.isBuffer(val)) { if (dataTypes[dialect].BLOB) { return dataTypes[dialect].BLOB.prototype.stringify(val); } return dataTypes.BLOB.prototype.stringify(val); } if (Array.isArray(val)) { var partialEscape = _.partial(escape, _, timeZone, dialect, format); if (dialect === 'postgres' && !format) { return dataTypes.ARRAY.prototype.stringify(val, {escape: escape}); } return val.map(partialEscape); } if (!val.replace) { throw new Error('Invalid value ' + val); } if (dialect === 'postgres' || dialect === 'sqlite' || dialect === 'mssql') { // http://www.postgresql.org/docs/8.2/static/sql-syntax-lexical.html#SQL-SYNTAX-STRINGS // http://stackoverflow.com/q/603572/130598 val = val.replace(/'/g, "''"); } else { val = val.replace(/[\0\n\r\b\t\\\'\"\x1a]/g, function(s) { switch (s) { case '\0': return '\\0'; case '\n': return '\\n'; case '\r': return '\\r'; case '\b': return '\\b'; case '\t': return '\\t'; case '\x1a': return '\\Z'; default: return '\\' + s; } }); } return (prependN ? "N'" : "'") + val + "'"; }
...
val_text = quoteWrapper + val_text + quoteWrapper
}
}
if(defaultVal === null || defaultVal === undefined) {
return true;
} else {
val_text = _.isString(val_text) && !val_text.match(/^sequelize\.[^(]+\(.*\)$/) ? SqlString.escape(_.trim(val_text, '"'), null, self.options.dialect) : val_text;
// don't prepend N for MSSQL when building models...
val_text = _.trimStart(val_text, 'N')
text[table] += spaces + spaces + spaces + attr + ": " + val_text;
}
}
else if (attr === "type" && self.tables[table][field][attr].indexOf('ENUM') === 0) {
...
function format(sql, values, timeZone, dialect) { values = [].concat(values); if (typeof sql !== 'string') { throw new Error('Invalid SQL string provided: ' + sql); } return sql.replace(/\?/g, function(match) { if (!values.length) { return match; } return escape(values.shift(), timeZone, dialect, true); }); }
n/a
function formatNamedParameters(sql, values, timeZone, dialect) { return sql.replace(/\:+(?!\d)(\w+)/g, function(value, key) { if ('postgres' === dialect && '::' === value.slice(0, 2)) { return value; } if (values[key] !== undefined) { return escape(values[key], timeZone, dialect, true); } else { throw new Error('Named parameter "' + value + '" has no value in the given object.'); } }); }
n/a