180 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2018 The go-ethereum Authors
 | 
						|
// This file is part of go-ethereum.
 | 
						|
//
 | 
						|
// go-ethereum is free software: you can redistribute it and/or modify
 | 
						|
// it under the terms of the GNU General Public License as published by
 | 
						|
// the Free Software Foundation, either version 3 of the License, or
 | 
						|
// (at your option) any later version.
 | 
						|
//
 | 
						|
// go-ethereum 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 General Public License for more details.
 | 
						|
//
 | 
						|
// You should have received a copy of the GNU General Public License
 | 
						|
// along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
 | 
						|
 | 
						|
// Command feed allows the user to create and update signed Swarm feeds
 | 
						|
package main
 | 
						|
 | 
						|
import cli "gopkg.in/urfave/cli.v1"
 | 
						|
 | 
						|
var (
 | 
						|
	ChequebookAddrFlag = cli.StringFlag{
 | 
						|
		Name:   "chequebook",
 | 
						|
		Usage:  "chequebook contract address",
 | 
						|
		EnvVar: SWARM_ENV_CHEQUEBOOK_ADDR,
 | 
						|
	}
 | 
						|
	SwarmAccountFlag = cli.StringFlag{
 | 
						|
		Name:   "bzzaccount",
 | 
						|
		Usage:  "Swarm account key file",
 | 
						|
		EnvVar: SWARM_ENV_ACCOUNT,
 | 
						|
	}
 | 
						|
	SwarmListenAddrFlag = cli.StringFlag{
 | 
						|
		Name:   "httpaddr",
 | 
						|
		Usage:  "Swarm HTTP API listening interface",
 | 
						|
		EnvVar: SWARM_ENV_LISTEN_ADDR,
 | 
						|
	}
 | 
						|
	SwarmPortFlag = cli.StringFlag{
 | 
						|
		Name:   "bzzport",
 | 
						|
		Usage:  "Swarm local http api port",
 | 
						|
		EnvVar: SWARM_ENV_PORT,
 | 
						|
	}
 | 
						|
	SwarmNetworkIdFlag = cli.IntFlag{
 | 
						|
		Name:   "bzznetworkid",
 | 
						|
		Usage:  "Network identifier (integer, default 3=swarm testnet)",
 | 
						|
		EnvVar: SWARM_ENV_NETWORK_ID,
 | 
						|
	}
 | 
						|
	SwarmSwapEnabledFlag = cli.BoolFlag{
 | 
						|
		Name:   "swap",
 | 
						|
		Usage:  "Swarm SWAP enabled (default false)",
 | 
						|
		EnvVar: SWARM_ENV_SWAP_ENABLE,
 | 
						|
	}
 | 
						|
	SwarmSwapAPIFlag = cli.StringFlag{
 | 
						|
		Name:   "swap-api",
 | 
						|
		Usage:  "URL of the Ethereum API provider to use to settle SWAP payments",
 | 
						|
		EnvVar: SWARM_ENV_SWAP_API,
 | 
						|
	}
 | 
						|
	SwarmSyncDisabledFlag = cli.BoolTFlag{
 | 
						|
		Name:   "nosync",
 | 
						|
		Usage:  "Disable swarm syncing",
 | 
						|
		EnvVar: SWARM_ENV_SYNC_DISABLE,
 | 
						|
	}
 | 
						|
	SwarmSyncUpdateDelay = cli.DurationFlag{
 | 
						|
		Name:   "sync-update-delay",
 | 
						|
		Usage:  "Duration for sync subscriptions update after no new peers are added (default 15s)",
 | 
						|
		EnvVar: SWARM_ENV_SYNC_UPDATE_DELAY,
 | 
						|
	}
 | 
						|
	SwarmMaxStreamPeerServersFlag = cli.IntFlag{
 | 
						|
		Name:   "max-stream-peer-servers",
 | 
						|
		Usage:  "Limit of Stream peer servers, 0 denotes unlimited",
 | 
						|
		EnvVar: SWARM_ENV_MAX_STREAM_PEER_SERVERS,
 | 
						|
		Value:  10000, // A very large default value is possible as stream servers have very small memory footprint
 | 
						|
	}
 | 
						|
	SwarmLightNodeEnabled = cli.BoolFlag{
 | 
						|
		Name:   "lightnode",
 | 
						|
		Usage:  "Enable Swarm LightNode (default false)",
 | 
						|
		EnvVar: SWARM_ENV_LIGHT_NODE_ENABLE,
 | 
						|
	}
 | 
						|
	SwarmDeliverySkipCheckFlag = cli.BoolFlag{
 | 
						|
		Name:   "delivery-skip-check",
 | 
						|
		Usage:  "Skip chunk delivery check (default false)",
 | 
						|
		EnvVar: SWARM_ENV_DELIVERY_SKIP_CHECK,
 | 
						|
	}
 | 
						|
	EnsAPIFlag = cli.StringSliceFlag{
 | 
						|
		Name:   "ens-api",
 | 
						|
		Usage:  "ENS API endpoint for a TLD and with contract address, can be repeated, format [tld:][contract-addr@]url",
 | 
						|
		EnvVar: SWARM_ENV_ENS_API,
 | 
						|
	}
 | 
						|
	SwarmApiFlag = cli.StringFlag{
 | 
						|
		Name:  "bzzapi",
 | 
						|
		Usage: "Specifies the Swarm HTTP endpoint to connect to",
 | 
						|
		Value: "http://127.0.0.1:8500",
 | 
						|
	}
 | 
						|
	SwarmRecursiveFlag = cli.BoolFlag{
 | 
						|
		Name:  "recursive",
 | 
						|
		Usage: "Upload directories recursively",
 | 
						|
	}
 | 
						|
	SwarmWantManifestFlag = cli.BoolTFlag{
 | 
						|
		Name:  "manifest",
 | 
						|
		Usage: "Automatic manifest upload (default true)",
 | 
						|
	}
 | 
						|
	SwarmUploadDefaultPath = cli.StringFlag{
 | 
						|
		Name:  "defaultpath",
 | 
						|
		Usage: "path to file served for empty url path (none)",
 | 
						|
	}
 | 
						|
	SwarmAccessGrantKeyFlag = cli.StringFlag{
 | 
						|
		Name:  "grant-key",
 | 
						|
		Usage: "grants a given public key access to an ACT",
 | 
						|
	}
 | 
						|
	SwarmAccessGrantKeysFlag = cli.StringFlag{
 | 
						|
		Name:  "grant-keys",
 | 
						|
		Usage: "grants a given list of public keys in the following file (separated by line breaks) access to an ACT",
 | 
						|
	}
 | 
						|
	SwarmUpFromStdinFlag = cli.BoolFlag{
 | 
						|
		Name:  "stdin",
 | 
						|
		Usage: "reads data to be uploaded from stdin",
 | 
						|
	}
 | 
						|
	SwarmUploadMimeType = cli.StringFlag{
 | 
						|
		Name:  "mime",
 | 
						|
		Usage: "Manually specify MIME type",
 | 
						|
	}
 | 
						|
	SwarmEncryptedFlag = cli.BoolFlag{
 | 
						|
		Name:  "encrypt",
 | 
						|
		Usage: "use encrypted upload",
 | 
						|
	}
 | 
						|
	SwarmAccessPasswordFlag = cli.StringFlag{
 | 
						|
		Name:   "password",
 | 
						|
		Usage:  "Password",
 | 
						|
		EnvVar: SWARM_ACCESS_PASSWORD,
 | 
						|
	}
 | 
						|
	SwarmDryRunFlag = cli.BoolFlag{
 | 
						|
		Name:  "dry-run",
 | 
						|
		Usage: "dry-run",
 | 
						|
	}
 | 
						|
	CorsStringFlag = cli.StringFlag{
 | 
						|
		Name:   "corsdomain",
 | 
						|
		Usage:  "Domain on which to send Access-Control-Allow-Origin header (multiple domains can be supplied separated by a ',')",
 | 
						|
		EnvVar: SWARM_ENV_CORS,
 | 
						|
	}
 | 
						|
	SwarmStorePath = cli.StringFlag{
 | 
						|
		Name:   "store.path",
 | 
						|
		Usage:  "Path to leveldb chunk DB (default <$GETH_ENV_DIR>/swarm/bzz-<$BZZ_KEY>/chunks)",
 | 
						|
		EnvVar: SWARM_ENV_STORE_PATH,
 | 
						|
	}
 | 
						|
	SwarmStoreCapacity = cli.Uint64Flag{
 | 
						|
		Name:   "store.size",
 | 
						|
		Usage:  "Number of chunks (5M is roughly 20-25GB) (default 5000000)",
 | 
						|
		EnvVar: SWARM_ENV_STORE_CAPACITY,
 | 
						|
	}
 | 
						|
	SwarmStoreCacheCapacity = cli.UintFlag{
 | 
						|
		Name:   "store.cache.size",
 | 
						|
		Usage:  "Number of recent chunks cached in memory (default 5000)",
 | 
						|
		EnvVar: SWARM_ENV_STORE_CACHE_CAPACITY,
 | 
						|
	}
 | 
						|
	SwarmCompressedFlag = cli.BoolFlag{
 | 
						|
		Name:  "compressed",
 | 
						|
		Usage: "Prints encryption keys in compressed form",
 | 
						|
	}
 | 
						|
	SwarmFeedNameFlag = cli.StringFlag{
 | 
						|
		Name:  "name",
 | 
						|
		Usage: "User-defined name for the new feed, limited to 32 characters. If combined with topic, it will refer to a subtopic with this name",
 | 
						|
	}
 | 
						|
	SwarmFeedTopicFlag = cli.StringFlag{
 | 
						|
		Name:  "topic",
 | 
						|
		Usage: "User-defined topic this feed is tracking, hex encoded. Limited to 64 hexadecimal characters",
 | 
						|
	}
 | 
						|
	SwarmFeedDataOnCreateFlag = cli.StringFlag{
 | 
						|
		Name:  "data",
 | 
						|
		Usage: "Initializes the feed with the given hex-encoded data. Data must be prefixed by 0x",
 | 
						|
	}
 | 
						|
	SwarmFeedManifestFlag = cli.StringFlag{
 | 
						|
		Name:  "manifest",
 | 
						|
		Usage: "Refers to the feed through a manifest",
 | 
						|
	}
 | 
						|
	SwarmFeedUserFlag = cli.StringFlag{
 | 
						|
		Name:  "user",
 | 
						|
		Usage: "Indicates the user who updates the feed",
 | 
						|
	}
 | 
						|
)
 |