Esempio n. 1
0
func (s Storage) Get(key string) ([]data.Post, error) {
	k := makeKey(s.context, key)
	value, err := get(s.context, k)
	if err != nil {
		return nil, err
	}
	return data.ReadPosts(bytes.NewBuffer(value.Bytes))
}
Esempio n. 2
0
func (ds DataStore) Get(key string) ([]data.Post, error) {
	file, err := os.Open(filepath.Join(string(ds), key))
	if err != nil {
		if os.IsNotExist(err) {
			return nil, nil
		}
		return nil, err
	}
	defer file.Close()
	return data.ReadPosts(file)
}
Esempio n. 3
0
func (ds DataStore) Post(key string, post data.Post) error {
	file, err := os.OpenFile(filepath.Join(string(ds), key), os.O_RDWR|os.O_CREATE, os.ModePerm)
	if err != nil {
		return err
	}
	defer file.Close()
	posts, err := data.ReadPosts(file)
	if err != nil && err != io.EOF {
		return err
	}
	if _, err = file.Seek(0, os.SEEK_SET); err != nil {
		return err
	}
	if err = file.Truncate(0); err != nil {
		return err
	}
	return data.AddPost(post, posts, file, MAX_POSTS_PER_KEY)
}
Esempio n. 4
0
func (s Storage) Post(key string, post data.Post) error {
	var status error
	if err := datastore.RunInTransaction(s.context, func(context appengine.Context) error {
		k := makeKey(context, key)
		value, err := get(context, k)
		if err != nil {
			return err
		}
		posts, status := data.ReadPosts(bytes.NewBuffer(value.Bytes))
		if status != nil && status != io.EOF {
			return nil
		}
		buffer := bytes.NewBuffer(nil)
		status = data.AddPost(post, posts, buffer, MAX_POSTS_PER_KEY)
		if status != nil {
			return nil
		}
		_, err = datastore.Put(context, k, &record{Bytes: buffer.Bytes()})
		return err
	}, nil); err != nil {
		return err
	}
	return status
}