2018-10-12 14:51:38 +02:00
|
|
|
// 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",
|
2018-11-12 13:04:13 +01:00
|
|
|
Usage: "Specifies the Swarm HTTP endpoint to connect to",
|
2018-10-12 14:51:38 +02:00
|
|
|
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",
|
|
|
|
}
|
|
|
|
)
|