| 
									
										
										
										
											2013-12-27 14:44:21 -05:00
										 |  |  | module.exports = function(client) { | 
					
						
							|  |  |  |   var _            = require('lodash'); | 
					
						
							|  |  |  |   var FluentChain  = require('fluent-chain'); | 
					
						
							|  |  |  |   var Promise      = require('../promise'); | 
					
						
							|  |  |  |   var Raw          = require('../raw'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // All of the publicly accessible methods of the builder which can be
 | 
					
						
							|  |  |  |   // composed into a query chain.
 | 
					
						
							|  |  |  |   var builderMethods = ['wrap', 'from', 'into', 'table', 'column', 'columns', 'distinct', | 
					
						
							|  |  |  |     'join', 'innerJoin', 'leftJoin', 'leftOuterJoin', 'rightJoin', 'rightOuterJoin', | 
					
						
							|  |  |  |     'outerJoin', 'fullOuterJoin', 'crossJoin', 'where', 'andWhere', 'orWhere', | 
					
						
							|  |  |  |     'whereRaw', 'orWhereRaw', 'whereExists', 'orWhereExists', 'whereNotExists', | 
					
						
							|  |  |  |     'orWhereNotExists', 'whereIn', 'orWhereIn', 'whereNotIn', 'orWhereNotIn', | 
					
						
							|  |  |  |     'whereNull', 'orWhereNull', 'whereNotNull', 'orWhereNotNull', 'whereBetween', | 
					
						
							|  |  |  |     'orWhereBetween', 'whereNotBetween', 'groupBy', 'orderBy', 'union', 'unionAll', | 
					
						
							|  |  |  |     'having', 'havingRaw', 'orHaving', 'orHavingRaw', 'offset', 'limit', 'count', | 
					
						
							|  |  |  |     'min', 'max', 'sum', 'increment', 'decrement', 'select', 'pluck', 'insert', | 
					
						
							|  |  |  |     'update', 'delete', 'del', 'returning', 'truncate', | 
					
						
							|  |  |  |     'forUpdate', 'forShare', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // And the ones that set flags rather than statements.
 | 
					
						
							|  |  |  |     'options', 'debug', 'transacting']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Create the interface for a "builder" object, which includes the "client",
 | 
					
						
							|  |  |  |   // "dialect", and "raw" methods for convenience.
 | 
					
						
							|  |  |  |   var BuilderInterface = FluentChain.extendChain(builderMethods, { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Create a new "raw" statement.
 | 
					
						
							|  |  |  |     raw: function BuilderInterface$raw(sql, bindings) { | 
					
						
							|  |  |  |       var raw = new Raw(sql, bindings); | 
					
						
							|  |  |  |       raw.__client = client; | 
					
						
							|  |  |  |       return raw; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Useful for debugging, allows tapping into the sql chain at a specific
 | 
					
						
							|  |  |  |     // point in the query building process.
 | 
					
						
							|  |  |  |     tapSql: function(handler) { | 
					
						
							|  |  |  |       var sql = this.toSql(); | 
					
						
							|  |  |  |       handler(sql.sql, sql.bindings); | 
					
						
							|  |  |  |       return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Public Interface:
 | 
					
						
							|  |  |  |   // -----------------
 | 
					
						
							|  |  |  |   BuilderInterface.prototype.toString = function BuilderInterface$toString() { | 
					
						
							| 
									
										
										
										
											2014-02-19 18:25:21 -05:00
										 |  |  |     return new client.QueryBuilder()._runChain(this.cloneChain()).toString(); | 
					
						
							| 
									
										
										
										
											2013-12-27 14:44:21 -05:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BuilderInterface.prototype.toSql = function BuilderInterface$toSql() { | 
					
						
							| 
									
										
										
										
											2014-02-19 18:25:21 -05:00
										 |  |  |     return new client.QueryBuilder()._runChain(this.cloneChain()).toSql(); | 
					
						
							| 
									
										
										
										
											2013-12-27 14:44:21 -05:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BuilderInterface.prototype.then = function BuilderInterface$then(onFulfilled, onRejected) { | 
					
						
							| 
									
										
										
										
											2014-02-19 18:25:21 -05:00
										 |  |  |     return client.runThen(new client.QueryBuilder()._runChain(this.cloneChain())).then(onFulfilled, onRejected); | 
					
						
							| 
									
										
										
										
											2013-12-27 14:44:21 -05:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Attach all of the top level promise methods that should be chainable.
 | 
					
						
							|  |  |  |   require('../coerceable')(BuilderInterface); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return BuilderInterface; | 
					
						
							|  |  |  | }; |