Added static document loading on start
This commit is contained in:
		
							parent
							
								
									32b4f842b7
								
							
						
					
					
						commit
						e403549e13
					
				
							
								
								
									
										2
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								TODO
									
									
									
									
									
								
							| @ -2,6 +2,8 @@ cache headers for static assets (and on document GET) | |||||||
| tests | tests | ||||||
| add feedback for errors to UI - esp. too long | add feedback for errors to UI - esp. too long | ||||||
| add about page | add about page | ||||||
|  | fix that chrome bug where it loads the doc twice | ||||||
|  | add link to about page | ||||||
| 
 | 
 | ||||||
| # shared version only | # shared version only | ||||||
| some way to do announcements easily (and use for ads) | some way to do announcements easily (and use for ads) | ||||||
|  | |||||||
							
								
								
									
										5
									
								
								about.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								about.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | # Haste | ||||||
|  | 
 | ||||||
|  | Sharing code is a good thing, and it should be _really_ easy to do it.  A lot of times, I want to show you something I'm seeing - and that's where we use pastebins. | ||||||
|  | 
 | ||||||
|  | Haste is the prettiest, easist to use pastebin every made. | ||||||
| @ -23,6 +23,10 @@ | |||||||
|     "port": 6379, |     "port": 6379, | ||||||
|     "db": 2, |     "db": 2, | ||||||
|     "expire": 3600 |     "expire": 3600 | ||||||
|  |   }, | ||||||
|  | 
 | ||||||
|  |   "documents": { | ||||||
|  |     "about": "./about.md" | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -34,14 +34,16 @@ RedisDocumentStore.connect = function(options) { | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // Save file in a key
 | // Save file in a key
 | ||||||
| RedisDocumentStore.prototype.set = function(key, data, callback) { | RedisDocumentStore.prototype.set = function(key, data, callback, skipExpire) { | ||||||
|   var _this = this; |   var _this = this; | ||||||
|   RedisDocumentStore.client.set(key, data, function(err, reply) { |   RedisDocumentStore.client.set(key, data, function(err, reply) { | ||||||
|     if (err) { |     if (err) { | ||||||
|       callback(false); |       callback(false); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|       _this.setExpiration(key); |       if (!skipExpire) { | ||||||
|  |         _this.setExpiration(key); | ||||||
|  |       } | ||||||
|       callback(true); |       callback(true); | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
|  | |||||||
							
								
								
									
										34
									
								
								server.js
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								server.js
									
									
									
									
									
								
							| @ -37,29 +37,43 @@ if (!config.storage.type) { | |||||||
| var Store = require('./lib/' + config.storage.type + '_document_store'); | var Store = require('./lib/' + config.storage.type + '_document_store'); | ||||||
| var preferredStore = new Store(config.storage); | var preferredStore = new Store(config.storage); | ||||||
| 
 | 
 | ||||||
|  | // Send the static documents into the preferred store, skipping expirations
 | ||||||
|  | for (var name in config.documents) { | ||||||
|  |   var path = config.documents[name]; | ||||||
|  |   fs.readFile(path, 'utf8', function(err, data) { | ||||||
|  |     if (data && !err) { | ||||||
|  |       preferredStore.set(name, data, function(cb) { | ||||||
|  |         winston.info('loaded static document', { name: name, path: path }); | ||||||
|  |       }, true); | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |       winston.warn('failed to load static document', { name: name, path: path }); | ||||||
|  |     } | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // Configure a static handler for the static files
 | // Configure a static handler for the static files
 | ||||||
| var staticHandler = new StaticHandler('./static', !!config.cacheStaticAssets); | var staticHandler = new StaticHandler('./static', !!config.cacheStaticAssets); | ||||||
| 
 | 
 | ||||||
|  | // Configure the document handler
 | ||||||
|  | var documentHandler = new DocumentHandler({ | ||||||
|  |   store: preferredStore, | ||||||
|  |   maxLength: config.maxLength, | ||||||
|  |   keyLength: config.keyLength | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // Set the server up and listen forever
 | // Set the server up and listen forever
 | ||||||
| http.createServer(function(request, response) { | http.createServer(function(request, response) { | ||||||
|   var incoming = url.parse(request.url, false); |   var incoming = url.parse(request.url, false); | ||||||
|   var handler = null; |   var handler = null; | ||||||
|   // Looking to add a new doc
 |   // Looking to add a new doc
 | ||||||
|   if (incoming.pathname.match(/^\/documents$/) && request.method == 'POST') { |   if (incoming.pathname.match(/^\/documents$/) && request.method == 'POST') { | ||||||
|     handler = new DocumentHandler({ |     return documentHandler.handlePost(request, response); | ||||||
|       keyLength: config.keyLength, |  | ||||||
|       maxLength: config.maxLength, |  | ||||||
|       store: preferredStore |  | ||||||
|     }); |  | ||||||
|     return handler.handlePost(request, response); |  | ||||||
|   } |   } | ||||||
|   // Looking up a doc
 |   // Looking up a doc
 | ||||||
|   var match = incoming.pathname.match(/^\/documents\/([A-Za-z0-9]+)$/); |   var match = incoming.pathname.match(/^\/documents\/([A-Za-z0-9]+)$/); | ||||||
|   if (request.method == 'GET' && match) { |   if (request.method == 'GET' && match) { | ||||||
|     handler = new DocumentHandler({ |     return documentHandler.handleGet(match[1], response); | ||||||
|       store: preferredStore |  | ||||||
|     }); |  | ||||||
|     return handler.handleGet(match[1], response); |  | ||||||
|   } |   } | ||||||
|   // Otherwise, look for static file
 |   // Otherwise, look for static file
 | ||||||
|   staticHandler.handle(incoming.pathname, response); |   staticHandler.handle(incoming.pathname, response); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 John Crepezzi
						John Crepezzi