| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | // 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 swarm | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"bytes" | 
					
						
							| 
									
										
										
										
											2017-03-22 18:20:33 +01:00
										 |  |  | 	"context" | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	"crypto/ecdsa" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 	"net" | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/accounts/abi/bind" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/common" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/contracts/chequebook" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/contracts/ens" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/crypto" | 
					
						
							| 
									
										
										
										
											2017-04-13 04:06:19 -05:00
										 |  |  | 	"github.com/ethereum/go-ethereum/ethclient" | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/log" | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/node" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/p2p" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/p2p/discover" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/rpc" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/swarm/api" | 
					
						
							|  |  |  | 	httpapi "github.com/ethereum/go-ethereum/swarm/api/http" | 
					
						
							| 
									
										
										
										
											2017-04-12 05:36:02 +05:30
										 |  |  | 	"github.com/ethereum/go-ethereum/swarm/fuse" | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/swarm/network" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/swarm/storage" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // the swarm stack | 
					
						
							|  |  |  | type Swarm struct { | 
					
						
							|  |  |  | 	config      *api.Config            // swarm configuration | 
					
						
							|  |  |  | 	api         *api.Api               // high level api layer (fs/manifest) | 
					
						
							|  |  |  | 	dns         api.Resolver           // DNS registrar | 
					
						
							|  |  |  | 	dbAccess    *network.DbAccess      // access to local chunk db iterator and storage counter | 
					
						
							|  |  |  | 	storage     storage.ChunkStore     // internal access to storage, common interface to cloud storage backends | 
					
						
							|  |  |  | 	dpa         *storage.DPA           // distributed preimage archive, the local API to the storage with document level storage/retrieval support | 
					
						
							|  |  |  | 	depo        network.StorageHandler // remote request handler, interface between bzz protocol and the storage | 
					
						
							|  |  |  | 	cloud       storage.CloudStore     // procurement, cloud storage backend (can multi-cloud) | 
					
						
							|  |  |  | 	hive        *network.Hive          // the logistic manager | 
					
						
							|  |  |  | 	backend     chequebook.Backend     // simple blockchain Backend | 
					
						
							|  |  |  | 	privateKey  *ecdsa.PrivateKey | 
					
						
							| 
									
										
										
										
											2017-01-05 11:57:41 +01:00
										 |  |  | 	corsString  string | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	swapEnabled bool | 
					
						
							| 
									
										
										
										
											2017-04-06 23:22:22 +01:00
										 |  |  | 	lstore      *storage.LocalStore // local store, needs to store for releasing resources after node stopped | 
					
						
							| 
									
										
										
										
											2017-04-12 05:36:02 +05:30
										 |  |  | 	sfs         *fuse.SwarmFS       // need this to cleanup all the active mounts on node exit | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type SwarmAPI struct { | 
					
						
							|  |  |  | 	Api     *api.Api | 
					
						
							|  |  |  | 	Backend chequebook.Backend | 
					
						
							|  |  |  | 	PrvKey  *ecdsa.PrivateKey | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Swarm) API() *SwarmAPI { | 
					
						
							|  |  |  | 	return &SwarmAPI{ | 
					
						
							|  |  |  | 		Api:     self.api, | 
					
						
							|  |  |  | 		Backend: self.backend, | 
					
						
							|  |  |  | 		PrvKey:  self.privateKey, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // creates a new swarm service instance | 
					
						
							|  |  |  | // implements node.Service | 
					
						
							| 
									
										
										
										
											2017-06-18 00:25:39 +02:00
										 |  |  | func NewSwarm(ctx *node.ServiceContext, backend chequebook.Backend, ensClient *ethclient.Client, config *api.Config, swapEnabled, syncEnabled bool, cors string) (self *Swarm, err error) { | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	if bytes.Equal(common.FromHex(config.PublicKey), storage.ZeroKey) { | 
					
						
							|  |  |  | 		return nil, fmt.Errorf("empty public key") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if bytes.Equal(common.FromHex(config.BzzKey), storage.ZeroKey) { | 
					
						
							|  |  |  | 		return nil, fmt.Errorf("empty bzz key") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	self = &Swarm{ | 
					
						
							|  |  |  | 		config:      config, | 
					
						
							|  |  |  | 		swapEnabled: swapEnabled, | 
					
						
							|  |  |  | 		backend:     backend, | 
					
						
							|  |  |  | 		privateKey:  config.Swap.PrivateKey(), | 
					
						
							| 
									
										
										
										
											2017-01-05 11:57:41 +01:00
										 |  |  | 		corsString:  cors, | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("Setting up Swarm service components")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	hash := storage.MakeHashFunc(config.ChunkerParams.Hash) | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 	self.lstore, err = storage.NewLocalStore(hash, config.StoreParams) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// setup local store | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("Set up local storage")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 	self.dbAccess = network.NewDbAccess(self.lstore) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("Set up local db access (iterator/counter)")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// set up the kademlia hive | 
					
						
							|  |  |  | 	self.hive = network.NewHive( | 
					
						
							|  |  |  | 		common.HexToHash(self.config.BzzKey), // key to hive (kademlia base address) | 
					
						
							|  |  |  | 		config.HiveParams,                    // configuration parameters | 
					
						
							|  |  |  | 		swapEnabled,                          // SWAP enabled | 
					
						
							|  |  |  | 		syncEnabled,                          // syncronisation enabled | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("Set up swarm network with Kademlia hive")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// setup cloud storage backend | 
					
						
							|  |  |  | 	cloud := network.NewForwarder(self.hive) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> set swarm forwarder as cloud storage backend")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	// setup cloud storage internal access layer | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 	self.storage = storage.NewNetStore(hash, self.lstore, cloud, config.StoreParams) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> swarm net store shared access layer to Swarm Chunk Store")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// set up Depo (storage handler = cloud storage access layer for incoming remote requests) | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 	self.depo = network.NewDepo(hash, self.lstore, self.storage) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> REmote Access to CHunks")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// set up DPA, the cloud storage local access layer | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 	dpaChunkStore := storage.NewDpaChunkStore(self.lstore, self.storage) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> Local Access to Swarm")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	// Swarm Hash Merklised Chunking for Arbitrary-length Document/File storage | 
					
						
							|  |  |  | 	self.dpa = storage.NewDPA(dpaChunkStore, self.config.ChunkerParams) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> Content Store API")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// set up high level api | 
					
						
							|  |  |  | 	transactOpts := bind.NewKeyedTransactor(self.privateKey) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-18 00:25:39 +02:00
										 |  |  | 	if ensClient == nil { | 
					
						
							|  |  |  | 		log.Warn("No ENS, please specify non-empty --ens-api to use domain name resolution") | 
					
						
							| 
									
										
										
										
											2017-04-13 04:06:19 -05:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2017-06-18 00:25:39 +02:00
										 |  |  | 		self.dns, err = ens.NewENS(transactOpts, config.EnsRoot, ensClient) | 
					
						
							| 
									
										
										
										
											2017-04-13 04:06:19 -05:00
										 |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return nil, err | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> Swarm Domain Name Registrar @ address %v", config.EnsRoot.Hex())) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	self.api = api.NewApi(self.dpa, self.dns) | 
					
						
							|  |  |  | 	// Manifests for Smart Hosting | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("-> Web3 virtual server API")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-12 05:36:02 +05:30
										 |  |  | 	self.sfs = fuse.NewSwarmFS(self.api) | 
					
						
							| 
									
										
										
										
											2017-03-23 19:26:06 +05:30
										 |  |  | 	log.Debug("-> Initializing Fuse file system") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	return self, nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | Start is called when the stack is started | 
					
						
							|  |  |  | * starts the network kademlia hive peer management | 
					
						
							|  |  |  | * (starts netStore level 0 api) | 
					
						
							|  |  |  | * starts DPA level 1 api (chunking -> store/retrieve requests) | 
					
						
							|  |  |  | * (starts level 2 api) | 
					
						
							|  |  |  | * starts http proxy server | 
					
						
							|  |  |  | * registers url scheme handlers for bzz, etc | 
					
						
							|  |  |  | * TODO: start subservices like sword, swear, swarmdns | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | // implements the node.Service interface | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | func (self *Swarm) Start(srv *p2p.Server) error { | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	connectPeer := func(url string) error { | 
					
						
							|  |  |  | 		node, err := discover.ParseNode(url) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return fmt.Errorf("invalid node URL: %v", err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 		srv.AddPeer(node) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	// set chequebook | 
					
						
							|  |  |  | 	if self.swapEnabled { | 
					
						
							|  |  |  | 		ctx := context.Background() // The initial setup has no deadline. | 
					
						
							|  |  |  | 		err := self.SetChequebook(ctx) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return fmt.Errorf("Unable to set chequebook for SWAP: %v", err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 		log.Debug(fmt.Sprintf("-> cheque book for SWAP: %v", self.config.Swap.Chequebook())) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 		log.Debug(fmt.Sprintf("SWAP disabled: no cheque book set")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Warn(fmt.Sprintf("Starting Swarm service")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	self.hive.Start( | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 		discover.PubkeyID(&srv.PrivateKey.PublicKey), | 
					
						
							|  |  |  | 		func() string { return srv.ListenAddr }, | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 		connectPeer, | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Info(fmt.Sprintf("Swarm network started on bzz address: %v", self.hive.Addr())) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	self.dpa.Start() | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Debug(fmt.Sprintf("Swarm DPA started")) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// start swarm http proxy server | 
					
						
							|  |  |  | 	if self.config.Port != "" { | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 		addr := net.JoinHostPort(self.config.ListenAddr, self.config.Port) | 
					
						
							| 
									
										
										
										
											2017-04-04 23:20:07 +01:00
										 |  |  | 		go httpapi.StartHttpServer(self.api, &httpapi.ServerConfig{ | 
					
						
							|  |  |  | 			Addr:       addr, | 
					
						
							|  |  |  | 			CorsString: self.corsString, | 
					
						
							|  |  |  | 		}) | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 		log.Info(fmt.Sprintf("Swarm http proxy started on %v", addr)) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-21 23:56:40 -07:00
										 |  |  | 		if self.corsString != "" { | 
					
						
							|  |  |  | 			log.Debug(fmt.Sprintf("Swarm http proxy started with corsdomain: %v", self.corsString)) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-01-05 11:57:41 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // implements the node.Service interface | 
					
						
							|  |  |  | // stops all component services. | 
					
						
							|  |  |  | func (self *Swarm) Stop() error { | 
					
						
							|  |  |  | 	self.dpa.Stop() | 
					
						
							|  |  |  | 	self.hive.Stop() | 
					
						
							|  |  |  | 	if ch := self.config.Swap.Chequebook(); ch != nil { | 
					
						
							|  |  |  | 		ch.Stop() | 
					
						
							|  |  |  | 		ch.Save() | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-09 00:01:12 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if self.lstore != nil { | 
					
						
							|  |  |  | 		self.lstore.DbStore.Close() | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-03-23 19:26:06 +05:30
										 |  |  | 	self.sfs.Stop() | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	return self.config.Save() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // implements the node.Service interface | 
					
						
							|  |  |  | func (self *Swarm) Protocols() []p2p.Protocol { | 
					
						
							| 
									
										
										
										
											2016-11-28 13:29:33 +01:00
										 |  |  | 	proto, err := network.Bzz(self.depo, self.backend, self.hive, self.dbAccess, self.config.Swap, self.config.SyncParams, self.config.NetworkId) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return []p2p.Protocol{proto} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // implements node.Service | 
					
						
							|  |  |  | // Apis returns the RPC Api descriptors the Swarm implementation offers | 
					
						
							|  |  |  | func (self *Swarm) APIs() []rpc.API { | 
					
						
							|  |  |  | 	return []rpc.API{ | 
					
						
							|  |  |  | 		// public APIs | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "bzz", | 
					
						
							|  |  |  | 			Version:   "0.1", | 
					
						
							|  |  |  | 			Service:   &Info{self.config, chequebook.ContractParams}, | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		// admin APIs | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "bzz", | 
					
						
							|  |  |  | 			Version:   "0.1", | 
					
						
							|  |  |  | 			Service:   api.NewControl(self.api, self.hive), | 
					
						
							|  |  |  | 			Public:    false, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "chequebook", | 
					
						
							|  |  |  | 			Version:   chequebook.Version, | 
					
						
							|  |  |  | 			Service:   chequebook.NewApi(self.config.Swap.Chequebook), | 
					
						
							|  |  |  | 			Public:    false, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-03-23 19:26:06 +05:30
										 |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "swarmfs", | 
					
						
							| 
									
										
										
										
											2017-04-12 05:36:02 +05:30
										 |  |  | 			Version:   fuse.Swarmfs_Version, | 
					
						
							| 
									
										
										
										
											2017-03-23 19:26:06 +05:30
										 |  |  | 			Service:   self.sfs, | 
					
						
							|  |  |  | 			Public:    false, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-04-06 23:22:22 +01:00
										 |  |  | 		// storage APIs | 
					
						
							|  |  |  | 		// DEPRECATED: Use the HTTP API instead | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "bzz", | 
					
						
							|  |  |  | 			Version:   "0.1", | 
					
						
							|  |  |  | 			Service:   api.NewStorage(self.api), | 
					
						
							|  |  |  | 			Public:    true, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Namespace: "bzz", | 
					
						
							|  |  |  | 			Version:   "0.1", | 
					
						
							|  |  |  | 			Service:   api.NewFileSystem(self.api), | 
					
						
							|  |  |  | 			Public:    false, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 		// {Namespace, Version, api.NewAdmin(self), false}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Swarm) Api() *api.Api { | 
					
						
							|  |  |  | 	return self.api | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // SetChequebook ensures that the local checquebook is set up on chain. | 
					
						
							|  |  |  | func (self *Swarm) SetChequebook(ctx context.Context) error { | 
					
						
							|  |  |  | 	err := self.config.Swap.SetChequebook(ctx, self.backend, self.config.Path) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-22 14:10:07 +02:00
										 |  |  | 	log.Info(fmt.Sprintf("new chequebook set (%v): saving config file, resetting all connections in the hive", self.config.Swap.Contract.Hex())) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	self.config.Save() | 
					
						
							|  |  |  | 	self.hive.DropAll() | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Local swarm without netStore | 
					
						
							|  |  |  | func NewLocalSwarm(datadir, port string) (self *Swarm, err error) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	prvKey, err := crypto.GenerateKey() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-28 13:29:33 +01:00
										 |  |  | 	config, err := api.NewConfig(datadir, common.Address{}, prvKey, network.NetworkId) | 
					
						
							| 
									
										
										
										
											2016-08-29 21:18:00 +02:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	config.Port = port | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dpa, err := storage.NewLocalDPA(datadir) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	self = &Swarm{ | 
					
						
							|  |  |  | 		api:    api.NewApi(dpa, nil), | 
					
						
							|  |  |  | 		config: config, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // serialisable info about swarm | 
					
						
							|  |  |  | type Info struct { | 
					
						
							|  |  |  | 	*api.Config | 
					
						
							|  |  |  | 	*chequebook.Params | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Info) Info() *Info { | 
					
						
							|  |  |  | 	return self | 
					
						
							|  |  |  | } |