2014-04-19 22:37:11 +00:00
|
|
|
package storage
|
|
|
|
|
|
|
|
import (
|
2014-11-22 18:45:14 +00:00
|
|
|
"log"
|
|
|
|
|
2014-06-24 21:21:06 +00:00
|
|
|
"github.com/ian-kent/Go-MailHog/mailhog/config"
|
|
|
|
"github.com/ian-kent/Go-MailHog/mailhog/data"
|
2014-04-19 22:37:11 +00:00
|
|
|
"labix.org/v2/mgo"
|
|
|
|
"labix.org/v2/mgo/bson"
|
|
|
|
)
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// MongoDB represents MongoDB backed storage backend
|
2014-04-20 19:33:42 +00:00
|
|
|
type MongoDB struct {
|
2014-06-24 21:21:06 +00:00
|
|
|
Session *mgo.Session
|
|
|
|
Config *config.Config
|
2014-04-20 19:33:42 +00:00
|
|
|
Collection *mgo.Collection
|
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// CreateMongoDB creates a MongoDB backed storage backend
|
2014-04-23 23:22:50 +00:00
|
|
|
func CreateMongoDB(c *config.Config) *MongoDB {
|
|
|
|
log.Printf("Connecting to MongoDB: %s\n", c.MongoUri)
|
2014-04-20 14:35:59 +00:00
|
|
|
session, err := mgo.Dial(c.MongoUri)
|
2014-06-24 21:21:06 +00:00
|
|
|
if err != nil {
|
2014-04-23 23:22:50 +00:00
|
|
|
log.Printf("Error connecting to MongoDB: %s", err)
|
2014-04-20 19:33:42 +00:00
|
|
|
return nil
|
2014-04-19 22:37:11 +00:00
|
|
|
}
|
2014-04-20 19:33:42 +00:00
|
|
|
return &MongoDB{
|
2014-06-24 21:21:06 +00:00
|
|
|
Session: session,
|
|
|
|
Config: c,
|
2014-04-20 19:33:42 +00:00
|
|
|
Collection: session.DB(c.MongoDb).C(c.MongoColl),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// Store stores a message in MongoDB and returns its storage ID
|
2014-06-24 21:21:06 +00:00
|
|
|
func (mongo *MongoDB) Store(m *data.Message) (string, error) {
|
2014-04-27 22:38:43 +00:00
|
|
|
err := mongo.Collection.Insert(m)
|
2014-04-19 22:37:11 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error inserting message: %s", err)
|
|
|
|
return "", err
|
|
|
|
}
|
2014-11-22 18:45:14 +00:00
|
|
|
return string(m.ID), nil
|
2014-04-19 22:37:11 +00:00
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// List returns a list of messages by index
|
2014-04-20 19:33:42 +00:00
|
|
|
func (mongo *MongoDB) List(start int, limit int) (*data.Messages, error) {
|
2014-04-20 15:05:50 +00:00
|
|
|
messages := &data.Messages{}
|
2014-04-22 19:39:54 +00:00
|
|
|
err := mongo.Collection.Find(bson.M{}).Skip(start).Limit(limit).Select(bson.M{
|
2014-06-24 21:21:06 +00:00
|
|
|
"id": 1,
|
|
|
|
"_id": 1,
|
|
|
|
"from": 1,
|
|
|
|
"to": 1,
|
2014-04-22 19:39:54 +00:00
|
|
|
"content.headers": 1,
|
2014-06-24 21:21:06 +00:00
|
|
|
"content.size": 1,
|
|
|
|
"created": 1,
|
2014-04-22 19:39:54 +00:00
|
|
|
}).All(messages)
|
2014-04-20 15:05:50 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error loading messages: %s", err)
|
|
|
|
return nil, err
|
|
|
|
}
|
2014-06-24 21:21:06 +00:00
|
|
|
return messages, nil
|
2014-04-20 15:05:50 +00:00
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// DeleteOne deletes an individual message by storage ID
|
2014-04-20 19:33:42 +00:00
|
|
|
func (mongo *MongoDB) DeleteOne(id string) error {
|
|
|
|
_, err := mongo.Collection.RemoveAll(bson.M{"id": id})
|
2014-04-20 16:09:06 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// DeleteAll deletes all messages stored in MongoDB
|
2014-04-20 19:33:42 +00:00
|
|
|
func (mongo *MongoDB) DeleteAll() error {
|
|
|
|
_, err := mongo.Collection.RemoveAll(bson.M{})
|
2014-04-20 16:09:06 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2014-11-22 18:45:14 +00:00
|
|
|
// Load loads an individual message by storage ID
|
2014-04-20 19:33:42 +00:00
|
|
|
func (mongo *MongoDB) Load(id string) (*data.Message, error) {
|
2014-04-19 22:37:11 +00:00
|
|
|
result := &data.Message{}
|
2014-04-20 19:33:42 +00:00
|
|
|
err := mongo.Collection.Find(bson.M{"id": id}).One(&result)
|
2014-04-19 22:37:11 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error loading message: %s", err)
|
|
|
|
return nil, err
|
|
|
|
}
|
2014-06-24 21:21:06 +00:00
|
|
|
return result, nil
|
2014-04-19 22:37:11 +00:00
|
|
|
}
|