71 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			71 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
|   | // Copyright 2016 The go-ethereum Authors | ||
|  | // This file is part of the go-ethereum library. | ||
|  | // | ||
|  | // The go-ethereum library is free software: you can redistribute it and/or modify | ||
|  | // it under the terms of the GNU Lesser General Public License as published by | ||
|  | // the Free Software Foundation, either version 3 of the License, or | ||
|  | // (at your option) any later version. | ||
|  | // | ||
|  | // The go-ethereum library is distributed in the hope that it will be useful, | ||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
|  | // GNU Lesser General Public License for more details. | ||
|  | // | ||
|  | // You should have received a copy of the GNU Lesser General Public License | ||
|  | // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. | ||
|  | 
 | ||
|  | package api | ||
|  | 
 | ||
|  | type Response struct { | ||
|  | 	MimeType string | ||
|  | 	Status   int | ||
|  | 	Size     int64 | ||
|  | 	// Content  []byte | ||
|  | 	Content string | ||
|  | } | ||
|  | 
 | ||
|  | // implements a service | ||
|  | type Storage struct { | ||
|  | 	api *Api | ||
|  | } | ||
|  | 
 | ||
|  | func NewStorage(api *Api) *Storage { | ||
|  | 	return &Storage{api} | ||
|  | } | ||
|  | 
 | ||
|  | // Put uploads the content to the swarm with a simple manifest speficying | ||
|  | // its content type | ||
|  | func (self *Storage) Put(content, contentType string) (string, error) { | ||
|  | 	return self.api.Put(content, contentType) | ||
|  | } | ||
|  | 
 | ||
|  | // Get retrieves the content from bzzpath and reads the response in full | ||
|  | // It returns the Response object, which serialises containing the | ||
|  | // response body as the value of the Content field | ||
|  | // NOTE: if error is non-nil, sResponse may still have partial content | ||
|  | // the actual size of which is given in len(resp.Content), while the expected | ||
|  | // size is resp.Size | ||
|  | func (self *Storage) Get(bzzpath string) (*Response, error) { | ||
|  | 	reader, mimeType, status, err := self.api.Get(bzzpath, true) | ||
|  | 	if err != nil { | ||
|  | 		return nil, err | ||
|  | 	} | ||
|  | 	quitC := make(chan bool) | ||
|  | 	expsize, err := reader.Size(quitC) | ||
|  | 	if err != nil { | ||
|  | 		return nil, err | ||
|  | 	} | ||
|  | 	body := make([]byte, expsize) | ||
|  | 	size, err := reader.Read(body) | ||
|  | 	if int64(size) == expsize { | ||
|  | 		err = nil | ||
|  | 	} | ||
|  | 	return &Response{mimeType, status, expsize, string(body[:size])}, err | ||
|  | } | ||
|  | 
 | ||
|  | // Modify(rootHash, path, contentHash, contentType) takes th e manifest trie rooted in rootHash, | ||
|  | // and merge on  to it. creating an entry w conentType (mime) | ||
|  | func (self *Storage) Modify(rootHash, path, contentHash, contentType string) (newRootHash string, err error) { | ||
|  | 	return self.api.Modify(rootHash+"/"+path, contentHash, contentType, true) | ||
|  | } |