├── .gitignore ├── LICENSE ├── README.md ├── cli ├── bcash-broadcast.js ├── bcash-instadump.js ├── bcash-tx.js ├── bcash-utxo.js └── common.js ├── electrum-servers.json ├── lib ├── electrum.js ├── make-tx.js ├── patch-bcoin-bcash.js ├── shapeshift.js ├── socket.js └── utxo.js ├── npm-shrinkwrap.json ├── package.json ├── screenshot.png └── utility └── tor-newnym.sh /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | GNU GENERAL PUBLIC LICENSE 2 | Version 3, 29 June 2007 3 | 4 | Copyright (C) 2007 Free Software Foundation, Inc. 5 | Everyone is permitted to copy and distribute verbatim copies 6 | of this license document, but changing it is not allowed. 7 | 8 | Preamble 9 | 10 | The GNU General Public License is a free, copyleft license for 11 | software and other kinds of works. 12 | 13 | The licenses for most software and other practical works are designed 14 | to take away your freedom to share and change the works. By contrast, 15 | the GNU General Public License is intended to guarantee your freedom to 16 | share and change all versions of a program--to make sure it remains free 17 | software for all its users. We, the Free Software Foundation, use the 18 | GNU General Public License for most of our software; it applies also to 19 | any other work released this way by its authors. You can apply it to 20 | your programs, too. 21 | 22 | When we speak of free software, we are referring to freedom, not 23 | price. Our General Public Licenses are designed to make sure that you 24 | have the freedom to distribute copies of free software (and charge for 25 | them if you wish), that you receive source code or can get it if you 26 | want it, that you can change the software or use pieces of it in new 27 | free programs, and that you know you can do these things. 28 | 29 | To protect your rights, we need to prevent others from denying you 30 | these rights or asking you to surrender the rights. Therefore, you have 31 | certain responsibilities if you distribute copies of the software, or if 32 | you modify it: responsibilities to respect the freedom of others. 33 | 34 | For example, if you distribute copies of such a program, whether 35 | gratis or for a fee, you must pass on to the recipients the same 36 | freedoms that you received. You must make sure that they, too, receive 37 | or can get the source code. And you must show them these terms so they 38 | know their rights. 39 | 40 | Developers that use the GNU GPL protect your rights with two steps: 41 | (1) assert copyright on the software, and (2) offer you this License 42 | giving you legal permission to copy, distribute and/or modify it. 43 | 44 | For the developers' and authors' protection, the GPL clearly explains 45 | that there is no warranty for this free software. For both users' and 46 | authors' sake, the GPL requires that modified versions be marked as 47 | changed, so that their problems will not be attributed erroneously to 48 | authors of previous versions. 49 | 50 | Some devices are designed to deny users access to install or run 51 | modified versions of the software inside them, although the manufacturer 52 | can do so. This is fundamentally incompatible with the aim of 53 | protecting users' freedom to change the software. The systematic 54 | pattern of such abuse occurs in the area of products for individuals to 55 | use, which is precisely where it is most unacceptable. Therefore, we 56 | have designed this version of the GPL to prohibit the practice for those 57 | products. If such problems arise substantially in other domains, we 58 | stand ready to extend this provision to those domains in future versions 59 | of the GPL, as needed to protect the freedom of users. 60 | 61 | Finally, every program is threatened constantly by software patents. 62 | States should not allow patents to restrict development and use of 63 | software on general-purpose computers, but in those that do, we wish to 64 | avoid the special danger that patents applied to a free program could 65 | make it effectively proprietary. To prevent this, the GPL assures that 66 | patents cannot be used to render the program non-free. 67 | 68 | The precise terms and conditions for copying, distribution and 69 | modification follow. 70 | 71 | TERMS AND CONDITIONS 72 | 73 | 0. Definitions. 74 | 75 | "This License" refers to version 3 of the GNU General Public License. 76 | 77 | "Copyright" also means copyright-like laws that apply to other kinds of 78 | works, such as semiconductor masks. 79 | 80 | "The Program" refers to any copyrightable work licensed under this 81 | License. Each licensee is addressed as "you". "Licensees" and 82 | "recipients" may be individuals or organizations. 83 | 84 | To "modify" a work means to copy from or adapt all or part of the work 85 | in a fashion requiring copyright permission, other than the making of an 86 | exact copy. The resulting work is called a "modified version" of the 87 | earlier work or a work "based on" the earlier work. 88 | 89 | A "covered work" means either the unmodified Program or a work based 90 | on the Program. 91 | 92 | To "propagate" a work means to do anything with it that, without 93 | permission, would make you directly or secondarily liable for 94 | infringement under applicable copyright law, except executing it on a 95 | computer or modifying a private copy. Propagation includes copying, 96 | distribution (with or without modification), making available to the 97 | public, and in some countries other activities as well. 98 | 99 | To "convey" a work means any kind of propagation that enables other 100 | parties to make or receive copies. Mere interaction with a user through 101 | a computer network, with no transfer of a copy, is not conveying. 102 | 103 | An interactive user interface displays "Appropriate Legal Notices" 104 | to the extent that it includes a convenient and prominently visible 105 | feature that (1) displays an appropriate copyright notice, and (2) 106 | tells the user that there is no warranty for the work (except to the 107 | extent that warranties are provided), that licensees may convey the 108 | work under this License, and how to view a copy of this License. If 109 | the interface presents a list of user commands or options, such as a 110 | menu, a prominent item in the list meets this criterion. 111 | 112 | 1. Source Code. 113 | 114 | The "source code" for a work means the preferred form of the work 115 | for making modifications to it. "Object code" means any non-source 116 | form of a work. 117 | 118 | A "Standard Interface" means an interface that either is an official 119 | standard defined by a recognized standards body, or, in the case of 120 | interfaces specified for a particular programming language, one that 121 | is widely used among developers working in that language. 122 | 123 | The "System Libraries" of an executable work include anything, other 124 | than the work as a whole, that (a) is included in the normal form of 125 | packaging a Major Component, but which is not part of that Major 126 | Component, and (b) serves only to enable use of the work with that 127 | Major Component, or to implement a Standard Interface for which an 128 | implementation is available to the public in source code form. A 129 | "Major Component", in this context, means a major essential component 130 | (kernel, window system, and so on) of the specific operating system 131 | (if any) on which the executable work runs, or a compiler used to 132 | produce the work, or an object code interpreter used to run it. 133 | 134 | The "Corresponding Source" for a work in object code form means all 135 | the source code needed to generate, install, and (for an executable 136 | work) run the object code and to modify the work, including scripts to 137 | control those activities. However, it does not include the work's 138 | System Libraries, or general-purpose tools or generally available free 139 | programs which are used unmodified in performing those activities but 140 | which are not part of the work. For example, Corresponding Source 141 | includes interface definition files associated with source files for 142 | the work, and the source code for shared libraries and dynamically 143 | linked subprograms that the work is specifically designed to require, 144 | such as by intimate data communication or control flow between those 145 | subprograms and other parts of the work. 146 | 147 | The Corresponding Source need not include anything that users 148 | can regenerate automatically from other parts of the Corresponding 149 | Source. 150 | 151 | The Corresponding Source for a work in source code form is that 152 | same work. 153 | 154 | 2. Basic Permissions. 155 | 156 | All rights granted under this License are granted for the term of 157 | copyright on the Program, and are irrevocable provided the stated 158 | conditions are met. This License explicitly affirms your unlimited 159 | permission to run the unmodified Program. The output from running a 160 | covered work is covered by this License only if the output, given its 161 | content, constitutes a covered work. This License acknowledges your 162 | rights of fair use or other equivalent, as provided by copyright law. 163 | 164 | You may make, run and propagate covered works that you do not 165 | convey, without conditions so long as your license otherwise remains 166 | in force. You may convey covered works to others for the sole purpose 167 | of having them make modifications exclusively for you, or provide you 168 | with facilities for running those works, provided that you comply with 169 | the terms of this License in conveying all material for which you do 170 | not control copyright. Those thus making or running the covered works 171 | for you must do so exclusively on your behalf, under your direction 172 | and control, on terms that prohibit them from making any copies of 173 | your copyrighted material outside their relationship with you. 174 | 175 | Conveying under any other circumstances is permitted solely under 176 | the conditions stated below. Sublicensing is not allowed; section 10 177 | makes it unnecessary. 178 | 179 | 3. Protecting Users' Legal Rights From Anti-Circumvention Law. 180 | 181 | No covered work shall be deemed part of an effective technological 182 | measure under any applicable law fulfilling obligations under article 183 | 11 of the WIPO copyright treaty adopted on 20 December 1996, or 184 | similar laws prohibiting or restricting circumvention of such 185 | measures. 186 | 187 | When you convey a covered work, you waive any legal power to forbid 188 | circumvention of technological measures to the extent such circumvention 189 | is effected by exercising rights under this License with respect to 190 | the covered work, and you disclaim any intention to limit operation or 191 | modification of the work as a means of enforcing, against the work's 192 | users, your or third parties' legal rights to forbid circumvention of 193 | technological measures. 194 | 195 | 4. Conveying Verbatim Copies. 196 | 197 | You may convey verbatim copies of the Program's source code as you 198 | receive it, in any medium, provided that you conspicuously and 199 | appropriately publish on each copy an appropriate copyright notice; 200 | keep intact all notices stating that this License and any 201 | non-permissive terms added in accord with section 7 apply to the code; 202 | keep intact all notices of the absence of any warranty; and give all 203 | recipients a copy of this License along with the Program. 204 | 205 | You may charge any price or no price for each copy that you convey, 206 | and you may offer support or warranty protection for a fee. 207 | 208 | 5. Conveying Modified Source Versions. 209 | 210 | You may convey a work based on the Program, or the modifications to 211 | produce it from the Program, in the form of source code under the 212 | terms of section 4, provided that you also meet all of these conditions: 213 | 214 | a) The work must carry prominent notices stating that you modified 215 | it, and giving a relevant date. 216 | 217 | b) The work must carry prominent notices stating that it is 218 | released under this License and any conditions added under section 219 | 7. This requirement modifies the requirement in section 4 to 220 | "keep intact all notices". 221 | 222 | c) You must license the entire work, as a whole, under this 223 | License to anyone who comes into possession of a copy. This 224 | License will therefore apply, along with any applicable section 7 225 | additional terms, to the whole of the work, and all its parts, 226 | regardless of how they are packaged. This License gives no 227 | permission to license the work in any other way, but it does not 228 | invalidate such permission if you have separately received it. 229 | 230 | d) If the work has interactive user interfaces, each must display 231 | Appropriate Legal Notices; however, if the Program has interactive 232 | interfaces that do not display Appropriate Legal Notices, your 233 | work need not make them do so. 234 | 235 | A compilation of a covered work with other separate and independent 236 | works, which are not by their nature extensions of the covered work, 237 | and which are not combined with it such as to form a larger program, 238 | in or on a volume of a storage or distribution medium, is called an 239 | "aggregate" if the compilation and its resulting copyright are not 240 | used to limit the access or legal rights of the compilation's users 241 | beyond what the individual works permit. Inclusion of a covered work 242 | in an aggregate does not cause this License to apply to the other 243 | parts of the aggregate. 244 | 245 | 6. Conveying Non-Source Forms. 246 | 247 | You may convey a covered work in object code form under the terms 248 | of sections 4 and 5, provided that you also convey the 249 | machine-readable Corresponding Source under the terms of this License, 250 | in one of these ways: 251 | 252 | a) Convey the object code in, or embodied in, a physical product 253 | (including a physical distribution medium), accompanied by the 254 | Corresponding Source fixed on a durable physical medium 255 | customarily used for software interchange. 256 | 257 | b) Convey the object code in, or embodied in, a physical product 258 | (including a physical distribution medium), accompanied by a 259 | written offer, valid for at least three years and valid for as 260 | long as you offer spare parts or customer support for that product 261 | model, to give anyone who possesses the object code either (1) a 262 | copy of the Corresponding Source for all the software in the 263 | product that is covered by this License, on a durable physical 264 | medium customarily used for software interchange, for a price no 265 | more than your reasonable cost of physically performing this 266 | conveying of source, or (2) access to copy the 267 | Corresponding Source from a network server at no charge. 268 | 269 | c) Convey individual copies of the object code with a copy of the 270 | written offer to provide the Corresponding Source. This 271 | alternative is allowed only occasionally and noncommercially, and 272 | only if you received the object code with such an offer, in accord 273 | with subsection 6b. 274 | 275 | d) Convey the object code by offering access from a designated 276 | place (gratis or for a charge), and offer equivalent access to the 277 | Corresponding Source in the same way through the same place at no 278 | further charge. You need not require recipients to copy the 279 | Corresponding Source along with the object code. If the place to 280 | copy the object code is a network server, the Corresponding Source 281 | may be on a different server (operated by you or a third party) 282 | that supports equivalent copying facilities, provided you maintain 283 | clear directions next to the object code saying where to find the 284 | Corresponding Source. Regardless of what server hosts the 285 | Corresponding Source, you remain obligated to ensure that it is 286 | available for as long as needed to satisfy these requirements. 287 | 288 | e) Convey the object code using peer-to-peer transmission, provided 289 | you inform other peers where the object code and Corresponding 290 | Source of the work are being offered to the general public at no 291 | charge under subsection 6d. 292 | 293 | A separable portion of the object code, whose source code is excluded 294 | from the Corresponding Source as a System Library, need not be 295 | included in conveying the object code work. 296 | 297 | A "User Product" is either (1) a "consumer product", which means any 298 | tangible personal property which is normally used for personal, family, 299 | or household purposes, or (2) anything designed or sold for incorporation 300 | into a dwelling. In determining whether a product is a consumer product, 301 | doubtful cases shall be resolved in favor of coverage. For a particular 302 | product received by a particular user, "normally used" refers to a 303 | typical or common use of that class of product, regardless of the status 304 | of the particular user or of the way in which the particular user 305 | actually uses, or expects or is expected to use, the product. A product 306 | is a consumer product regardless of whether the product has substantial 307 | commercial, industrial or non-consumer uses, unless such uses represent 308 | the only significant mode of use of the product. 309 | 310 | "Installation Information" for a User Product means any methods, 311 | procedures, authorization keys, or other information required to install 312 | and execute modified versions of a covered work in that User Product from 313 | a modified version of its Corresponding Source. The information must 314 | suffice to ensure that the continued functioning of the modified object 315 | code is in no case prevented or interfered with solely because 316 | modification has been made. 317 | 318 | If you convey an object code work under this section in, or with, or 319 | specifically for use in, a User Product, and the conveying occurs as 320 | part of a transaction in which the right of possession and use of the 321 | User Product is transferred to the recipient in perpetuity or for a 322 | fixed term (regardless of how the transaction is characterized), the 323 | Corresponding Source conveyed under this section must be accompanied 324 | by the Installation Information. But this requirement does not apply 325 | if neither you nor any third party retains the ability to install 326 | modified object code on the User Product (for example, the work has 327 | been installed in ROM). 328 | 329 | The requirement to provide Installation Information does not include a 330 | requirement to continue to provide support service, warranty, or updates 331 | for a work that has been modified or installed by the recipient, or for 332 | the User Product in which it has been modified or installed. Access to a 333 | network may be denied when the modification itself materially and 334 | adversely affects the operation of the network or violates the rules and 335 | protocols for communication across the network. 336 | 337 | Corresponding Source conveyed, and Installation Information provided, 338 | in accord with this section must be in a format that is publicly 339 | documented (and with an implementation available to the public in 340 | source code form), and must require no special password or key for 341 | unpacking, reading or copying. 342 | 343 | 7. Additional Terms. 344 | 345 | "Additional permissions" are terms that supplement the terms of this 346 | License by making exceptions from one or more of its conditions. 347 | Additional permissions that are applicable to the entire Program shall 348 | be treated as though they were included in this License, to the extent 349 | that they are valid under applicable law. If additional permissions 350 | apply only to part of the Program, that part may be used separately 351 | under those permissions, but the entire Program remains governed by 352 | this License without regard to the additional permissions. 353 | 354 | When you convey a copy of a covered work, you may at your option 355 | remove any additional permissions from that copy, or from any part of 356 | it. (Additional permissions may be written to require their own 357 | removal in certain cases when you modify the work.) You may place 358 | additional permissions on material, added by you to a covered work, 359 | for which you have or can give appropriate copyright permission. 360 | 361 | Notwithstanding any other provision of this License, for material you 362 | add to a covered work, you may (if authorized by the copyright holders of 363 | that material) supplement the terms of this License with terms: 364 | 365 | a) Disclaiming warranty or limiting liability differently from the 366 | terms of sections 15 and 16 of this License; or 367 | 368 | b) Requiring preservation of specified reasonable legal notices or 369 | author attributions in that material or in the Appropriate Legal 370 | Notices displayed by works containing it; or 371 | 372 | c) Prohibiting misrepresentation of the origin of that material, or 373 | requiring that modified versions of such material be marked in 374 | reasonable ways as different from the original version; or 375 | 376 | d) Limiting the use for publicity purposes of names of licensors or 377 | authors of the material; or 378 | 379 | e) Declining to grant rights under trademark law for use of some 380 | trade names, trademarks, or service marks; or 381 | 382 | f) Requiring indemnification of licensors and authors of that 383 | material by anyone who conveys the material (or modified versions of 384 | it) with contractual assumptions of liability to the recipient, for 385 | any liability that these contractual assumptions directly impose on 386 | those licensors and authors. 387 | 388 | All other non-permissive additional terms are considered "further 389 | restrictions" within the meaning of section 10. If the Program as you 390 | received it, or any part of it, contains a notice stating that it is 391 | governed by this License along with a term that is a further 392 | restriction, you may remove that term. If a license document contains 393 | a further restriction but permits relicensing or conveying under this 394 | License, you may add to a covered work material governed by the terms 395 | of that license document, provided that the further restriction does 396 | not survive such relicensing or conveying. 397 | 398 | If you add terms to a covered work in accord with this section, you 399 | must place, in the relevant source files, a statement of the 400 | additional terms that apply to those files, or a notice indicating 401 | where to find the applicable terms. 402 | 403 | Additional terms, permissive or non-permissive, may be stated in the 404 | form of a separately written license, or stated as exceptions; 405 | the above requirements apply either way. 406 | 407 | 8. Termination. 408 | 409 | You may not propagate or modify a covered work except as expressly 410 | provided under this License. Any attempt otherwise to propagate or 411 | modify it is void, and will automatically terminate your rights under 412 | this License (including any patent licenses granted under the third 413 | paragraph of section 11). 414 | 415 | However, if you cease all violation of this License, then your 416 | license from a particular copyright holder is reinstated (a) 417 | provisionally, unless and until the copyright holder explicitly and 418 | finally terminates your license, and (b) permanently, if the copyright 419 | holder fails to notify you of the violation by some reasonable means 420 | prior to 60 days after the cessation. 421 | 422 | Moreover, your license from a particular copyright holder is 423 | reinstated permanently if the copyright holder notifies you of the 424 | violation by some reasonable means, this is the first time you have 425 | received notice of violation of this License (for any work) from that 426 | copyright holder, and you cure the violation prior to 30 days after 427 | your receipt of the notice. 428 | 429 | Termination of your rights under this section does not terminate the 430 | licenses of parties who have received copies or rights from you under 431 | this License. If your rights have been terminated and not permanently 432 | reinstated, you do not qualify to receive new licenses for the same 433 | material under section 10. 434 | 435 | 9. Acceptance Not Required for Having Copies. 436 | 437 | You are not required to accept this License in order to receive or 438 | run a copy of the Program. Ancillary propagation of a covered work 439 | occurring solely as a consequence of using peer-to-peer transmission 440 | to receive a copy likewise does not require acceptance. However, 441 | nothing other than this License grants you permission to propagate or 442 | modify any covered work. These actions infringe copyright if you do 443 | not accept this License. Therefore, by modifying or propagating a 444 | covered work, you indicate your acceptance of this License to do so. 445 | 446 | 10. Automatic Licensing of Downstream Recipients. 447 | 448 | Each time you convey a covered work, the recipient automatically 449 | receives a license from the original licensors, to run, modify and 450 | propagate that work, subject to this License. You are not responsible 451 | for enforcing compliance by third parties with this License. 452 | 453 | An "entity transaction" is a transaction transferring control of an 454 | organization, or substantially all assets of one, or subdividing an 455 | organization, or merging organizations. If propagation of a covered 456 | work results from an entity transaction, each party to that 457 | transaction who receives a copy of the work also receives whatever 458 | licenses to the work the party's predecessor in interest had or could 459 | give under the previous paragraph, plus a right to possession of the 460 | Corresponding Source of the work from the predecessor in interest, if 461 | the predecessor has it or can get it with reasonable efforts. 462 | 463 | You may not impose any further restrictions on the exercise of the 464 | rights granted or affirmed under this License. For example, you may 465 | not impose a license fee, royalty, or other charge for exercise of 466 | rights granted under this License, and you may not initiate litigation 467 | (including a cross-claim or counterclaim in a lawsuit) alleging that 468 | any patent claim is infringed by making, using, selling, offering for 469 | sale, or importing the Program or any portion of it. 470 | 471 | 11. Patents. 472 | 473 | A "contributor" is a copyright holder who authorizes use under this 474 | License of the Program or a work on which the Program is based. The 475 | work thus licensed is called the contributor's "contributor version". 476 | 477 | A contributor's "essential patent claims" are all patent claims 478 | owned or controlled by the contributor, whether already acquired or 479 | hereafter acquired, that would be infringed by some manner, permitted 480 | by this License, of making, using, or selling its contributor version, 481 | but do not include claims that would be infringed only as a 482 | consequence of further modification of the contributor version. For 483 | purposes of this definition, "control" includes the right to grant 484 | patent sublicenses in a manner consistent with the requirements of 485 | this License. 486 | 487 | Each contributor grants you a non-exclusive, worldwide, royalty-free 488 | patent license under the contributor's essential patent claims, to 489 | make, use, sell, offer for sale, import and otherwise run, modify and 490 | propagate the contents of its contributor version. 491 | 492 | In the following three paragraphs, a "patent license" is any express 493 | agreement or commitment, however denominated, not to enforce a patent 494 | (such as an express permission to practice a patent or covenant not to 495 | sue for patent infringement). To "grant" such a patent license to a 496 | party means to make such an agreement or commitment not to enforce a 497 | patent against the party. 498 | 499 | If you convey a covered work, knowingly relying on a patent license, 500 | and the Corresponding Source of the work is not available for anyone 501 | to copy, free of charge and under the terms of this License, through a 502 | publicly available network server or other readily accessible means, 503 | then you must either (1) cause the Corresponding Source to be so 504 | available, or (2) arrange to deprive yourself of the benefit of the 505 | patent license for this particular work, or (3) arrange, in a manner 506 | consistent with the requirements of this License, to extend the patent 507 | license to downstream recipients. "Knowingly relying" means you have 508 | actual knowledge that, but for the patent license, your conveying the 509 | covered work in a country, or your recipient's use of the covered work 510 | in a country, would infringe one or more identifiable patents in that 511 | country that you have reason to believe are valid. 512 | 513 | If, pursuant to or in connection with a single transaction or 514 | arrangement, you convey, or propagate by procuring conveyance of, a 515 | covered work, and grant a patent license to some of the parties 516 | receiving the covered work authorizing them to use, propagate, modify 517 | or convey a specific copy of the covered work, then the patent license 518 | you grant is automatically extended to all recipients of the covered 519 | work and works based on it. 520 | 521 | A patent license is "discriminatory" if it does not include within 522 | the scope of its coverage, prohibits the exercise of, or is 523 | conditioned on the non-exercise of one or more of the rights that are 524 | specifically granted under this License. You may not convey a covered 525 | work if you are a party to an arrangement with a third party that is 526 | in the business of distributing software, under which you make payment 527 | to the third party based on the extent of your activity of conveying 528 | the work, and under which the third party grants, to any of the 529 | parties who would receive the covered work from you, a discriminatory 530 | patent license (a) in connection with copies of the covered work 531 | conveyed by you (or copies made from those copies), or (b) primarily 532 | for and in connection with specific products or compilations that 533 | contain the covered work, unless you entered into that arrangement, 534 | or that patent license was granted, prior to 28 March 2007. 535 | 536 | Nothing in this License shall be construed as excluding or limiting 537 | any implied license or other defenses to infringement that may 538 | otherwise be available to you under applicable patent law. 539 | 540 | 12. No Surrender of Others' Freedom. 541 | 542 | If conditions are imposed on you (whether by court order, agreement or 543 | otherwise) that contradict the conditions of this License, they do not 544 | excuse you from the conditions of this License. If you cannot convey a 545 | covered work so as to satisfy simultaneously your obligations under this 546 | License and any other pertinent obligations, then as a consequence you may 547 | not convey it at all. For example, if you agree to terms that obligate you 548 | to collect a royalty for further conveying from those to whom you convey 549 | the Program, the only way you could satisfy both those terms and this 550 | License would be to refrain entirely from conveying the Program. 551 | 552 | 13. Use with the GNU Affero General Public License. 553 | 554 | Notwithstanding any other provision of this License, you have 555 | permission to link or combine any covered work with a work licensed 556 | under version 3 of the GNU Affero General Public License into a single 557 | combined work, and to convey the resulting work. The terms of this 558 | License will continue to apply to the part which is the covered work, 559 | but the special requirements of the GNU Affero General Public License, 560 | section 13, concerning interaction through a network will apply to the 561 | combination as such. 562 | 563 | 14. Revised Versions of this License. 564 | 565 | The Free Software Foundation may publish revised and/or new versions of 566 | the GNU General Public License from time to time. Such new versions will 567 | be similar in spirit to the present version, but may differ in detail to 568 | address new problems or concerns. 569 | 570 | Each version is given a distinguishing version number. If the 571 | Program specifies that a certain numbered version of the GNU General 572 | Public License "or any later version" applies to it, you have the 573 | option of following the terms and conditions either of that numbered 574 | version or of any later version published by the Free Software 575 | Foundation. If the Program does not specify a version number of the 576 | GNU General Public License, you may choose any version ever published 577 | by the Free Software Foundation. 578 | 579 | If the Program specifies that a proxy can decide which future 580 | versions of the GNU General Public License can be used, that proxy's 581 | public statement of acceptance of a version permanently authorizes you 582 | to choose that version for the Program. 583 | 584 | Later license versions may give you additional or different 585 | permissions. However, no additional obligations are imposed on any 586 | author or copyright holder as a result of your choosing to follow a 587 | later version. 588 | 589 | 15. Disclaimer of Warranty. 590 | 591 | THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY 592 | APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT 593 | HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY 594 | OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, 595 | THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 596 | PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM 597 | IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF 598 | ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 599 | 600 | 16. Limitation of Liability. 601 | 602 | IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING 603 | WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS 604 | THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY 605 | GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE 606 | USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF 607 | DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD 608 | PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), 609 | EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF 610 | SUCH DAMAGES. 611 | 612 | 17. Interpretation of Sections 15 and 16. 613 | 614 | If the disclaimer of warranty and limitation of liability provided 615 | above cannot be given local legal effect according to their terms, 616 | reviewing courts shall apply local law that most closely approximates 617 | an absolute waiver of all civil liability in connection with the 618 | Program, unless a warranty or assumption of liability accompanies a 619 | copy of the Program in return for a fee. 620 | 621 | END OF TERMS AND CONDITIONS 622 | 623 | How to Apply These Terms to Your New Programs 624 | 625 | If you develop a new program, and you want it to be of the greatest 626 | possible use to the public, the best way to achieve this is to make it 627 | free software which everyone can redistribute and change under these terms. 628 | 629 | To do so, attach the following notices to the program. It is safest 630 | to attach them to the start of each source file to most effectively 631 | state the exclusion of warranty; and each file should have at least 632 | the "copyright" line and a pointer to where the full notice is found. 633 | 634 | {one line to give the program's name and a brief idea of what it does.} 635 | Copyright (C) {year} {name of author} 636 | 637 | This program is free software: you can redistribute it and/or modify 638 | it under the terms of the GNU General Public License as published by 639 | the Free Software Foundation, either version 3 of the License, or 640 | (at your option) any later version. 641 | 642 | This program is distributed in the hope that it will be useful, 643 | but WITHOUT ANY WARRANTY; without even the implied warranty of 644 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 645 | GNU General Public License for more details. 646 | 647 | You should have received a copy of the GNU General Public License 648 | along with this program. If not, see . 649 | 650 | Also add information on how to contact you by electronic and paper mail. 651 | 652 | If the program does terminal interaction, make it output a short 653 | notice like this when it starts in an interactive mode: 654 | 655 | {project} Copyright (C) {year} {fullname} 656 | This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. 657 | This is free software, and you are welcome to redistribute it 658 | under certain conditions; type `show c' for details. 659 | 660 | The hypothetical commands `show w' and `show c' should show the appropriate 661 | parts of the General Public License. Of course, your program's commands 662 | might be different; for a GUI interface, you would use an "about box". 663 | 664 | You should also get your employer (if you work as a programmer) or school, 665 | if any, to sign a "copyright disclaimer" for the program, if necessary. 666 | For more information on this, and how to apply and follow the GNU GPL, see 667 | . 668 | 669 | The GNU General Public License does not permit incorporating your program 670 | into proprietary programs. If your program is a subroutine library, you 671 | may consider it more useful to permit linking proprietary applications with 672 | the library. If this is what you want to do, use the GNU Lesser General 673 | Public License instead of this License. But first, please read 674 | . 675 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # bcash-instadump 2 | 3 | CLI tools for insta-dumping bcash in exchange for bitcoins (`bcash-instadump`), 4 | creating bcash-compatible transactions (`bcash-tx`), 5 | listing unspent bcash outputs (`bcash-utxo`) 6 | and broadcasting raw bcash transactions (`bcash-broadcast`). 7 | 8 | No bcash wallet or exchange account necessary. 9 | 10 | Developed by [Nadav Ivgi](https://www.bitrated.com/nadav) ([@shesek](https://twitter.com/shesek)) 11 | of [Bitrated](https://www.bitrated.com/). 12 | *1HNDUy34hrqoTEChCZZjb6vWAU9APAKG78* 13 | 14 | **TL;DR** 15 | 16 | $ bcash-instadump --tor --key LmyBcashKeyWIF --payout 1myBtcAddr 17 | # confirm the details and press Y to sell your bcash and get your bitcoins 18 | 19 | (yes, that's it! but do read the whole thing to fully understand the risks involved.) 20 | 21 | **Warning! This software could put your bitcoins, bcash and privacy at risk.** 22 | 23 | These tools are meant for technically advanced users. 24 | Using them incorrectly (or even correctly!) could result in loss of funds and privacy. 25 | If you don't consider yourself a technical user, please seek advice from someone who is. 26 | 27 | Make sure to read *all* the instructions *carefully* before doing anything. 28 | You can use these tools in a way that doesn't risk your bitcoins, 29 | by moving them out first. There are also instructions for signing offline. 30 | See "*Instructions*" below. 31 | 32 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND. USE AT YOUR OWK RISK. 33 | 34 | ## Install 35 | 36 | *Requires nodejs 6.0.0 or newer.* 37 | 38 | The quick, less safe way: 39 | 40 | $ npm install -g bcash-instadump 41 | 42 | The safer way: find a Git commit reference published by a third-party security auditor that you trust, then: 43 | 44 | $ npm install -g git://github.com/shesek/bcash-instadump#[GIT-COMMIT-SHA256-HERE] 45 | 46 | There are currently no security audits that I'm aware of, 47 | but the code is < 500 SLOC if you want to review it yourself. 48 | If you do, you should publicly announce the hash for the Git commit you reviewed 49 | (and [tell me!](https://github.com/shesek/bcash-instadump/issues/new)). 50 | 51 | ## CLI tools 52 | 53 | ### `bcash-instadump` - dump bcash on ShapeShift 54 | 55 | $ bcash-instadump --key LmyBcashKeyWIF --payout 1myBtcAddr 56 | 57 | Insta-dump the bcash held in the provided `--key` (in base58 WIF) 58 | on [ShapeShift](https://shapeshift.io/) 59 | and send the purchased BTC to the bitcoin address provided in `--payout`. 60 | Shows details and asks for a confirmation before actually dumping. 61 | 62 | Using `--key ` will load all of the unspent outputs belonging to ``. 63 | To add specific inputs instead, you can use `--input txid,vout,amount,key`. 64 | Loading unspent outputs is done using the 65 | [Electrum bcash servers](https://github.com/shesek/bcash-instadump/blob/master/electrum-servers.json) 66 | (see "*Privacy considerations*" below). 67 | 68 | You can specify both `--key` and `--input` multiple times, 69 | or specify a file with `--keys keys.txt` and `--inputs utxos.csv`. 70 | All the inputs will be joined together in a single transaction (see "*Privacy considerations*" below). 71 | Only `p2pkh` scripts are currently supported. 72 | 73 | You can set your bcash refund address with `--refund
` 74 | (used by ShapeShift in case anything goes wrong with the exchange). 75 | Defaults to the address associated with the first key provided. 76 | 77 | Specify `--feerate` to control the transaction fee (in `satoshis/byte`). 78 | Defaults to `rand(50,100)`. 79 | 80 | Use `--whateverjustdump` to skip all confirmations (for exchange rates, miner fees, etc) and just dump. 81 | This is probably a terrible idea. 82 | 83 | ShapeShift is used with a referrer code that tips the author of this tool. 84 | This can be disabled with `--noreferral`. 85 | 86 | The `--(no)proxy`, `--tor` and `--electrum` options are the same as for `bcash-tx` (below). 87 | 88 | See `bcash-instadump --help` for the full list of options. 89 | 90 | **The author of this tool is not affiliated with ShapeShift.** 91 | There are reports of orders failing with ShapeShift 92 | despite the funds being sent. Reaching out to ShapeShift's 93 | customer support should usually resolve that. 94 | 95 | ---- 96 | 97 | Screenshot of `bcash-instadump` in action (dummy details, of course): 98 | 99 | ![Screenshot](https://raw.githubusercontent.com/shesek/bcash-instadump/master/screenshot.png?z) 100 | 101 | ---- 102 | 103 | ### `bcash-tx`- make bcash-compatible transactions 104 | 105 | $ bcash-tx --input txid:vout:amount:key --output 1BcashAddr:ALL --feerate 250 106 | 107 | Create and sign a bcash-compatible transaction with the provided inputs and outputs. 108 | The transaction will be invalid on the Bitcoin network. 109 | 110 | `--output addr:amount` can be used multiple times. 111 | Use `ALL` as the `amount` to send the maximum available amount minus tx fees, or specify the amount in whole bitcoins. 112 | `--feerate` is only relevant if `ALL` is used. 113 | 114 | Specify `--inspect` to print the decoded transaction instead of its raw hex representation. 115 | 116 | Use `--broadcast` to broadcast the transaction via an Electrum bcash server 117 | (also see `bcash-broadcast` if you already have a raw transaction ready). 118 | 119 | Use `--proxy [socks4a|socks5h]://user:pass@host:port` or `--tor` to connect to the Electrum server over a proxy, 120 | or `--noproxy` to connect without one (see "*Privacy considerations*" below). 121 | 122 | You can configure a custom Electrum bcash server using `--electrum [tls|tcp]://host:port`. 123 | If not provided, one is chosen at random (from `electrum-servers.json`). 124 | 125 | See `bcash-tx --help` for the full list of options. 126 | 127 | ---- 128 | 129 | ### `bcash-utxo` - list unspent bcash outputs 130 | 131 | $ bcash-utxo 1myFirstAddr 1myOtherAddr ... 132 | 133 | Get the unspent bcash outputs for the provided address(es) from the Electrum bcash servers, 134 | and print them as CSV (`txid,vout,amount,address` format). 135 | 136 | You may also provide keys instead of addresses. 137 | In this case, the CSV format would be `txid,vout,amount,key` 138 | (same as the format expected by `bcash-instadump` and `bcash-tx`). 139 | 140 | Specify `--file ` to read the list of addresses/keys from `` (one per line) instead of from arguments. 141 | 142 | This will leak information to the Electrum bcash servers (see "*Privacy considerations*" below). 143 | 144 | The `--(no)proxy`, `--tor` and `--electrum` options are the same as for `bcash-tx`. 145 | 146 | See `bcash-utxo --help` for the full list of options. 147 | 148 | ---- 149 | 150 | ### `bcash-broadcast` - broadcast raw bcash transactions 151 | 152 | $ bcash-broadcast 153 | 154 | Broadcasts the provided `rawtx` (in hex) to the bcash network via an Electrum bcash server. 155 | 156 | The `--(no)proxy`, `--tor` and `--electrum` options are the same as for `bcash-tx`. 157 | 158 | See `bcash-broadcast --help` for the full list of options. 159 | 160 | ---- 161 | 162 | ## Instructions & gotchas 163 | 164 | ### Protect your BTC 165 | 166 | **Move your bitcoins first!** To avoid risking your BTC, keys with a BTC balance should never be exposed to this tool. 167 | Make sure the keys provided to this software are *entirely emptied of BTC* and hold BCH only. 168 | 169 | ### Extracting unspent outputs and keys 170 | 171 | #### From Bitcoin Core: 172 | 173 | ```bash 174 | $ bitcoin-cli listunspent | jq -c '.[] | [.txid,.vout,.amount,.address]' | tr -d '[]"' \ 175 | | awk -F, '{"bitcoin-cli dumpprivkey "$4 | getline key; print $1 FS $2 FS $3 FS key }' \ 176 | > utxos.csv 177 | ``` 178 | 179 | #### From Electrum: 180 | 181 | ```bash 182 | $ electrum listunspent | jq -c '.[] | [.prevout_hash,.prevout_n,.value,.address]' | tr -d '[]"' \ 183 | | awk -F, '{"electrum getprivatekeys "$4"|jq -r .[0]" | getline key; print $1 FS $2 FS $3 FS key }' \ 184 | > utxos.csv 185 | 186 | # @TODO assumes p2pkh outputs, will break with multisig 187 | ``` 188 | 189 | #### From a list of keys: 190 | 191 | Prepare `keys.txt` with a list of base58 WIF keys (one per line), then: 192 | 193 | ```bash 194 | $ bcash-utxo -f keys.txt > utxos.csv 195 | ``` 196 | 197 | WARNING: looking up the unspent outputs associated with your addresses 198 | will leak information to the Electrum bcash servers. 199 | See "*Privacy considerations*" below for suggestions to improve privacy. 200 | 201 | #### Dumping from the UTXO CSV file 202 | 203 | ```bash 204 | $ bcash-instadump --inputs utxos.csv --payout 1myBtcAddr 205 | ``` 206 | 207 | ### Signing offline 208 | 209 | To sign offline, you can use [browserify](http://browserify.org/) to create a portable version 210 | of `bcash-tx` with all of its dependencies bundled in a single `.js` file, 211 | and run that from the offline machine (requires nodejs >=6.0.0). 212 | 213 | ```bash 214 | # Online machine - prepare portable bundle 215 | satoshi@hot:~$ npm install -g browserify 216 | satoshi@hot:~$ git clone https://github.com/shesek/bcash-instadump#[COMMIT-SHA256] && cd bcash-instadump 217 | satoshi@hot:~$ npm install 218 | satoshi@hot:~$ browserify --bare cli/bcash-tx.js > /media/usb/bcash-tx.js 219 | 220 | # Online machine - prepare list of outputs 221 | satoshi@hot:~$ bcash-utxo --tor 1myFirstAddr 1myOtherAddr > /media/usb/utxos.csv 222 | # WARNING: will leak information to the Electrum bcash servers, see "Privacy considerations" 223 | 224 | # Offline machine - sign bcash transaction 225 | satoshi@cold:~$ edit utxos.csv # change 4th column from address to key 226 | satoshi@cold:~$ node /media/usb/bcash-tx.js --inputs utxos.csv --output 1myBcashAddr:ALL --inspect 227 | satoshi@cold:~$ node /media/usb/bcash-tx.js --inputs utxos.csv --output 1myBcashAddr:ALL > /media/usb/signed.tx 228 | 229 | # Online machine - broadcast to the bcash network 230 | satoshi@hot:~$ bcash-broadcast --tor `cat /media/usb/signed.tx` 231 | ``` 232 | 233 | ### Splitting coins 234 | 235 | If your coins are too big to be sold with one order (due to ShapeShift's limits), 236 | you can split them up with `bcash-tx` and make several orders. 237 | 238 | For example, to split a 10 BCH output into two 4.995 BCH orders 239 | (leaving some for mining fees), 240 | use something like: 241 | 242 | ```bash 243 | $ bcash-tx --tor --broadcast --key LmyBcashKeyWithLargeOutput \ 244 | --output 1myBcashAddr1:4.995 --output 1myBcashAddr2:4.995 245 | # take note of the resulting 246 | $ bcash-instadump --tor --input ,0,4.995,LkeyForAddr1 --payout 1myBtcAddr1 247 | $ bcash-instadump --tor --input ,1,4.995,LkeyForAddr2 --payout 1myBtcAddr2 248 | ``` 249 | 250 | ### Dump specific UTXOs 251 | 252 | `bcash-instadump --key ` will by default dump all of the 253 | unspent outputs available to ``. 254 | To select specific ones, use: 255 | 256 | ```bash 257 | $ bcash-utxo --tor LmyBcashKey > utxos.csv 258 | $ edit utxos.csv # leave just the ones you want to dump 259 | $ bcash-instadump --tor --inputs utxos.csv --payout 1btcAddr 260 | ``` 261 | 262 | ### Privacy considerations 263 | 264 | #### Leaking data to the public blockchain 265 | 266 | Merging your unspent outputs together (in a single multi-input transaction) 267 | will reveal the link between them (and their associated addresses) 268 | on the public bitcoin/bcash blockchains, *to the entire world*. 269 | 270 | It is recommended to invoke `bcash-instadump` multiple times, 271 | once for each unspent output being sold (creating a separate 1-in,1-out tx each time) 272 | and with a different `--payout` address. Ideally, this should also be spread out over time. 273 | This could be accomplished using a bash script along the lines of: 274 | 275 | ```bash 276 | $ cat utxos.csv | xargs -L 1 bash -c 'sleep $[ ( $RANDOM % 3600 ) ]s && 277 | bcash-instadump --input $0 --payout `bitcoin-cli getnewaddress` --whateverjustdump' 278 | ``` 279 | 280 | #### Leaking data to ShapeShift 281 | 282 | Selling all of your unspent outputs from the same IP address 283 | will reveal the link between your outputs (and their associated addresses) to ShapeShift 284 | and to anyone gaining access to their systems (via hacking, a legal warrant, or otherwise). 285 | 286 | It is recommended to sell one output at a time and use `--proxy` or `--tor` to connect over a proxy. 287 | Preferably, use a proxy with a different public IP address for each request 288 | (otherwise the transactions would not be linked to your real IP address, but still linked to each-other. see more on that below.) 289 | 290 | #### Leaking data to the Electrum bcash servers 291 | 292 | The Electrum bcash servers are used for two purposes: 293 | *(1)* Broadcasting raw transactions to the bcash network 294 | (for `bcash-instadump` and `bcash-tx --broadcast`), 295 | and *(2)* Fetching the unspent bcash outputs associated with your addresses 296 | (for `bcash-utxo` and `bcash-instadump --key). 297 | 298 | This gives the Electrum servers the ability to link your transactions/addresses/outputs 299 | to each-other and to your IP address. 300 | 301 | To completely mitigate this leakage, you should ideally broadcast transactions and 302 | fetch unspent outputs using a bcash full node under your full control, connected over Tor. 303 | 304 | However, if running a full node is not possible or desirable, 305 | you can also retain better privacy by using a proxy - 306 | with the same caveat mentioned above regarding different public IP addresses. 307 | To switch public IP addresses between address lookups, 308 | you can use Tor, the [tor-newnym](https://raw.githubusercontent.com/shesek/bcash-instadump/master/utility/tor-newnym.sh) 309 | script available in `utility/`, and something like: 310 | 311 | ```bash 312 | $ cat addresses-or-keys.txt | xargs -L 1 bash -c ' 313 | ./tor-newnym.sh && sleep $[ ( $RANDOM % 180) ]s && 314 | bcash-utxo --tor $0' \ 315 | > utxos.csv 316 | ``` 317 | 318 | Under the default Tor configuration, the control port is 9151 and authentication is done using the cookie file. 319 | This should work: ```./tor-newnym.sh 9151 "`cat /path/to/tor/control_auth_cookie`"```. 320 | See the [Tor manual](https://www.torproject.org/docs/tor-manual.html.en#ControlPort) for 321 | more information about control port configuration and authentication. 322 | 323 | (`tor-newnym` will hopefully soon be integrated into the tool itself. PRs welcome!) 324 | 325 | In addition, it is also recommended that you use a random Electrum bcash server for each lookup. 326 | This is the default behaviour if you don't provide a specific server via `--electrum`. 327 | 328 | ## Contributing 329 | 330 | Pull requests are welcome! Some interesting next steps are: 331 | 332 | - A tool to prepare the list of unspent outputs based on the HD master seed. 333 | 334 | - Creating a GUI frontend (packaged as a browser extension, an [Electron](https://electron.atom.io/) app, or something else?) 335 | 336 | - Optimize input-merging behavior to improve privacy. 337 | 338 | - Multi-signature support (currently only `p2pkh` scripts are supported) 339 | 340 | - Connect to the Tor control port to change circuits (`NEWNYM` signal) between 341 | address lookups in `bcash-utxo`. 342 | 343 | - Tests (there aren't any! :scream::scream:) 344 | 345 | - Have any other cool ideas? [Let me know!](https://github.com/shesek/bcash-instadump/issues/new) 346 | 347 | ## License 348 | 349 | This software is released under the GPL v3 license. 350 | See LICENSE for more details. 351 | -------------------------------------------------------------------------------- /cli/bcash-broadcast.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const 4 | C = require('chalk') 5 | , Electrum = require('../lib/electrum') 6 | , { formatSat, initArgs, printErr } = require('./common') 7 | 8 | const args = require('commander') 9 | .version(require('../package.json').version) 10 | .description('Broadcast raw transactions to the bcash network.') 11 | .usage('[options] ') 12 | 13 | .option('-e, --electrum ', 'electrum server, must be bcash-compatible [default: random server]') 14 | .option('-p, --proxy ', 'proxy for connecting to electrum server') 15 | .option('-t, --tor', 'shortcut for --proxy socks5h://127.0.0.1:9150') 16 | .option('-N, --noproxy', 'set if you\'re sure you don\'t want to use a proxy') 17 | 18 | .on('--help', _ => console.log('\n README:', C.underline('https://github.com/shesek/bcash-instadump'), '(really, do!)\n')) 19 | 20 | .parse(process.argv) 21 | 22 | if (!args.args.length) args.help() 23 | initArgs(args) 24 | 25 | Electrum(args.electrum, args.proxy).broadcast(args.args[0]) 26 | .then(txid => console.log(C.green('(success)'), 'transaction broadcast to the bcash network:', C.yellowBright(txid))) 27 | .catch(printErr) 28 | -------------------------------------------------------------------------------- /cli/bcash-instadump.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | const 3 | C = require('chalk') 4 | , util = require('util') 5 | , inquirer = require('inquirer') 6 | , Electrum = require('../lib/electrum') 7 | , ShapeShift = require('../lib/shapeshift') 8 | , makeTx = require('../lib/make-tx') 9 | , {keysUtxo} = require('../lib/utxo') 10 | 11 | , { collector, parseInput, toSat, formatSat, initArgs, checkFee, printErr, info } = require('./common') 12 | 13 | const dummyOut = { address: '1BitcoinEaterAddressDontSendf59kuE', value: 'ALL' } 14 | , pair = 'BCH_BTC' 15 | 16 | const formatNum = (num, asStr) => asStr ? (+num).toFixed(8) : +(+num).toFixed(8) 17 | , formatDate = ts => new Date(ts).toLocaleString() 18 | 19 | const args = require('commander') 20 | .version(require('../package.json').version) 21 | .description(`${C.red('DUMP bcash')} 💩 ${C.green('HODL bitcoin')} 🚀:🌔`) 22 | 23 | .option('-i, --input ', 'add input in txid:vout:amount:key format (amount in whole bitcoins, key in base58)', collector(parseInput), []) 24 | .option('-I, --inputs ', 'read inputs from CSV file') 25 | .option('-k, --key ', 'load unspent outputs for and add them', collector(x => x), []) 26 | .option('-K, --keys ', 'read keys from file (one per line)') 27 | .option('-P, --payout
', 'bitcoin address for receiving the converted bitcoins (required)') 28 | .option('-r, --refund
', 'bcash address for refunds if anything goes wrong with the exchange [default: the address of the first key]') 29 | .option('-f, --feerate ', 'set the feerate in satoshis/byte [default: rand(50,100)]', x => parseInt(x)) 30 | 31 | .option('-e, --electrum ', 'electrum server, must be bcash-compatible [default: random server]') 32 | .option('-p, --proxy ', 'proxy for connecting to electrum server and shapeshift') 33 | .option('-t, --tor', 'shortcut for --proxy socks5://127.0.0.1:9050') 34 | .option('-N, --noproxy', 'set if you\'re sure you don\'t want to use a proxy') 35 | 36 | .option('--crazyfee', 'disable the crazy fee sanity check (allow feerate>2000)') 37 | .option('--noreferral', 'don\'t use referrer code to tip the author of this software') 38 | .option('--whateverjustdump', 'skip all confirmations (for exchange rates, miner fees, etc) and just dump. this is probably a terrible idea.') 39 | 40 | .on('--help', _ => console.log('\n Example:\n\n $ bcash-instadump --input txid,vout,amount,key --payout 1BtcAddrGimmeRogersCoins' 41 | + '\n\n README:', C.underline('https://github.com/shesek/bcash-instadump'), '(really, do!)\n')) 42 | 43 | .parse(process.argv) 44 | 45 | initArgs(args) 46 | if (!(args.input.length || args.key.length) || !args.payout) args.help() 47 | 48 | if (args.key.length) info('loading unspent outputs for', C.yellowBright(args.key.length), 'keys') 49 | 50 | keysUtxo(args.key, args).then(inputs => args.input.concat(inputs)).then(inputs => { 51 | if (!inputs.length) return Promise.reject('no unspent outputs found for the provided key(s)') 52 | 53 | const shift = ShapeShift({ proxy: args.proxy, noreferral: args.noreferral }) 54 | , txTmp = makeTx(inputs, [ dummyOut ], args.feerate) // @XXX builds and discards a dummy tx to estimate size/fee/amounts, somewhat wasteful 55 | , txVal = txTmp.getOutputValue() 56 | , refund = args.refund || txTmp.view.getCoin(txTmp.inputs[0]).getAddress().toString() 57 | 58 | info('fetching market info') 59 | return shift.marketinfo(pair) 60 | .then(market => (info('ShapeShift market info:', util.inspect(market, { colors: true }).replace(/\n /g,'')), market)) 61 | .then(market => verifyLimits(market, formatSat(txVal))) 62 | 63 | .then(_ => info('creating order to dump', C.yellowBright(formatSat(txVal), 'BCH'))) 64 | .then(_ => shift.openOrder(pair, formatSat(txVal), refund, args.payout)) 65 | .then(order => makeVerifyTx(order, inputs, txVal) 66 | .then(tx => Electrum(args.electrum, args.proxy).broadcast(tx.toRaw().toString('hex'))) 67 | .then(txid => printSuccess(order, txid))) 68 | }).catch(printErr) 69 | 70 | const verifyLimits = (market, amount) => 71 | !market.minimum || !market.limit ? Promise.reject('missing market limits, probably a temporary ShapeShift issue. try again in a few minutes.') 72 | : toSat(amount) < toSat(''+market.minimum) ? Promise.reject('cannot sell '+amount+' BCH, minimum is '+market.minimum+' BCH') 73 | : toSat(amount) > toSat(''+market.limit) ? Promise.reject('cannot sell '+amount+' BCH, maximum is '+market.limit+' BCH') 74 | : info('within limits', C.yellowBright(market.minimum, '<=', amount, '<=', market.limit)) 75 | 76 | const makeVerifyTx = (order, inputs, txVal) => { 77 | const tx = makeTx(inputs, [ { address: order.deposit, value: txVal } ]) 78 | , btcs = order.withdrawalAmount 79 | , rateE = (toSat(btcs)/tx.getOutputValue()).toFixed(8) 80 | , rateF = (toSat(btcs)/tx.getInputValue()).toFixed(8) 81 | 82 | if (!args.crazyfee) checkFee(tx) 83 | 84 | console.log('\nShapeShift order', C.yellowBright(order.orderId)+':\n') 85 | console.log(' Payout address (BTC):', C.yellowBright(order.withdrawal)) 86 | console.log(' Deposit address (BCH):', C.yellowBright(order.deposit)) 87 | console.log(' Refund address (BCH):', C.yellowBright(order.returnAddress), C.yellow(!args.refund ? '(none provided, defaulted to the address of the first key)' : '')) 88 | console.log('\n Fixed fee:', C.yellowBright(order.minerFee, 'BTC'), C.yellow('(charged by ShapeShift)')) 89 | console.log('\n '+C.red(C.bold('DUMP'), formatSat(txVal), C.bold('BCH'))+',', C.green(C.bold('GET'), btcs, C.bold('BTC'))+'\n') 90 | console.log(' Quoted rate: 1 BCH =', C.yellowBright(order.quotedRate), 'BTC', C.yellow('(before ShapeShift\'s fixed fee and mining fees)')) 91 | console.log(' Actual rate: 1 BCH =', C.yellowBright(rateE), 'BTC', C.yellow('(including ShapeShift\'s fixed fee)')) 92 | console.log(' Total rate: 1 BCH =', C.yellowBright(rateF), 'BTC', C.yellow('(including your bcash miner fees, too)')) 93 | console.log('\n ' + C.cyan.underline(order.url), args.noproxy ? '' : '\n '+C.red('(warn)'), C.gray('don\'t forget your proxy when opening links in browser')) 94 | console.log('\n ' + C.underline('order expires'), 'in', C.yellowBright(Math.ceil((order.expiration-Date.now())/60000)), 'minutes' 95 | , '('+C.yellowBright(formatDate(order.expiration))+')') 96 | 97 | console.log('\nTransaction', C.yellowBright(tx.txid())+':\n') 98 | console.log(' Inputs:', C.yellowBright(formatSat(tx.getInputValue()), 'BCH'), 'from', C.yellowBright(tx.inputs.length+' outpoints') 99 | , C.yellow('('+tx.inputs.map(inv => [inv.prevout.txid().substr(0, 7), inv.prevout.index].join(':')).join(', ')+')')) 100 | console.log(' Output:', C.yellowBright(formatSat(tx.getOutputValue()), 'BCH'), 'to', C.yellowBright(tx.outputs[0].getAddress()), C.yellow('(ShapeShift\'s deposit address)')) 101 | console.log(' Tx size:', C.yellowBright(tx.getVirtualSize()+'b')+',', 'fee:', C.yellowBright(formatSat(tx.getFee()), 'BCH'), '(rate:', C.yellowBright(Math.round(tx.getRate(tx.view)/1000,2)), 'satoshis/byte)') 102 | if (tx.inputs.length > 1) console.log(' ', C.red('(warn)'), C.gray('merging multiple inputs together could harm your privacy. See README.md for more details.')) 103 | 104 | console.log('\nPlease make sure everything checks out. Once confirmed, this cannot be undone.') 105 | console.log('Press Y to confirm and dump or N to abort and print the bcash transaction without broadcasting it.\n') 106 | 107 | return confirm('DUMP bcash, HODL bitcoin?') 108 | .catch(_ => { 109 | console.log('\n'+C.red('(canceled)'), 'not sending transaction:\n') 110 | console.log(util.inspect(tx.inspect(), { depth: 5, colors: true })+'\n') 111 | console.log(C.yellow('(rawtx)'), tx.toRaw().toString('hex')+'\n') 112 | info('you can send this transaction manually using:\n $ bcash-broadcast \n') 113 | return Promise.reject('user aborted') 114 | }) 115 | .then(_ => !nearExpiry(order) ? tx : Promise.reject('ShapeShift order expired, aborting transaction. be quicker next time!')) 116 | } 117 | 118 | const confirm = message => args.whateverjustdump 119 | ? (console.log(C.green('?'), C.bold(message), C.gray('--whateverjustdump, skipping')), Promise.resolve(true)) 120 | : inquirer.prompt([ { name: 'ok', type: 'confirm', message, default: false } ]) 121 | .then(r => r.ok || Promise.reject('user aborted')) 122 | 123 | const nearExpiry = order => Date.now() > order.expiration - 60000 // safety margin of 1 minute 124 | 125 | const printSuccess = (order, txid) => { 126 | console.log('\n'+C.green.bold('(success)'), 'bcash dumped in tx', C.yellowBright(txid)+'\n') 127 | console.log(' Order status:', C.cyan.underline(order.url)) 128 | console.log(' Transaction: ', C.cyan.underline(txUrl(txid))) 129 | args.noproxy || console.log(' ' + C.red('(warn)'), C.gray('don\'t forget your proxy when opening links in browser')) 130 | console.log('\n '+C.yellowBright(order.withdrawalAmount, 'BTC'), 'are coming your way (after 3 bcash confirmations).', C.bold('HODL strong!')+'\n') 131 | console.log('Make sure to keep a copy of the order and transaction details for future reference.\n') 132 | } 133 | const txUrl = txid => 'https://blockchair.com/bitcoin-cash/transaction/' + txid 134 | -------------------------------------------------------------------------------- /cli/bcash-tx.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const 4 | C = require('chalk') 5 | , util = require('util') 6 | , Electrum = require('../lib/electrum') 7 | , makeTx = require('../lib/make-tx') 8 | , {keysUtxo} = require('../lib/utxo') 9 | 10 | , { parseInput, parseOutput, collector, initArgs, checkFee, printErr, info } = require('./common') 11 | 12 | const args = require('commander') 13 | .version(require('../package.json').version) 14 | .description('Create and sign a bcash-compatible transaction with the provided inputs and outputs.\n The transaction will be invalid on the Bitcoin network.') 15 | 16 | .option('-i, --input ', 'add input in txid:vout:amount:key) format (amount in whole bitcoins, key in base58)', collector(parseInput), []) 17 | .option('-I, --inputs ', 'read inputs from CSV file') 18 | .option('-k, --key ', 'load unspent outputs for and add them', collector(x => x), []) 19 | .option('-K, --keys ', 'read keys from file (one per line)') 20 | .option('-o, --output ', 'add output in `address:amount` format (use ALL as the amount to send the maximum available amount minus tx fees)', collector(parseOutput), []) 21 | .option('-f, --feerate ', 'set the feerate in satoshis/byte [default: rand(50,100)]', x => parseInt(x)) 22 | 23 | .option('-d, --inspect', 'print decoded transaction (instead of raw hex)') 24 | .option('-b, --broadcast', 'broadcast tx to the bcash network. you should --inspect first. recommended with --tor.') 25 | 26 | .option('-e, --electrum ', 'electrum server, must be bcash-compatible [default: random server]') 27 | .option('-p, --proxy ', 'proxy for connecting to electrum server') 28 | .option('-t, --tor', 'shortcut for --proxy socks5h://127.0.0.1:9150') 29 | .option('-N, --noproxy', 'set if you\'re sure you don\'t want to use a proxy') 30 | 31 | .option('--crazyfee', 'disable the crazy fee sanity check (allow feerate>1000)') 32 | 33 | .on('--help', _ => console.log('\n Examples:\n' 34 | + '\n $ bcash-tx --input txid:vout:amount:key --output 1BcashAddr:ALL --feerate 250 --inspect' 35 | + '\n $ bcash-tx --input txid:vout:amount:key --output 1BcashAddr:10.337 --broadcast --tor' 36 | + '\n\n README:', C.underline('https://github.com/shesek/bcash-instadump'), '(really, do!)\n')) 37 | 38 | .parse(process.argv) 39 | 40 | initArgs(args, !!(args.broadcast || args.key.length || args.keys)) 41 | if (!(args.input.length || args.key.length) || !args.output.length) args.help() 42 | 43 | if (args.key.length) info('loading unspent outputs for', C.yellowBright(args.key.length), 'keys') 44 | 45 | keysUtxo(args.key, args).then(inputs => args.input.concat(inputs)).then(inputs => { 46 | if (!inputs.length) return Promise.reject('no unspent outputs found for the provided key(s)') 47 | 48 | const tx = makeTx(inputs, args.output, args.feerate) 49 | if (!args.crazyfee) checkFee(tx) 50 | 51 | if (args.inspect) console.log(util.inspect(tx.inspect(), { depth: 5, colors: true })) 52 | else console.log(tx.toRaw().toString('hex')) 53 | 54 | if (args.broadcast) { 55 | Electrum(args.electrum, args.proxy) 56 | .broadcast(tx.toRaw().toString('hex')) 57 | .then(txid => console.log(C.green('(success)'), 'transaction broadcast to the bcash network:', C.yellowBright(txid))) 58 | .catch(printErr) 59 | } 60 | }) 61 | -------------------------------------------------------------------------------- /cli/bcash-utxo.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const 4 | C = require('chalk') 5 | , loadUtxo = require('../lib/utxo') 6 | 7 | , { readLines, formatSat, initArgs, printErr, info } = require('./common') 8 | 9 | const args = require('commander') 10 | .version(require('../package.json').version) 11 | .description('List unspent outputs for the provided address(es) or key(s)' 12 | + '\n in CSV format: txid,vout,amount,addressOrKey') 13 | .usage('[options] ') 14 | 15 | .option('-f, --file ', 'read addressOrKey from instead of command-line arguments (one per line)') 16 | 17 | .option('-e, --electrum ', 'electrum server, must be bcash-compatible [default: random server]') 18 | .option('-p, --proxy ', 'set proxy for broadcasting transactions') 19 | .option('-t, --tor', 'shortcut for --proxy socks5h://127.0.0.1:9150') 20 | .option('-N, --noproxy', 'set if you\'re sure you don\'t want to use a proxy') 21 | 22 | .on('--help', _ => console.log('\n Example:\n\n $ bcash-utxo --tor 1myFirstAddr 1myOtherAddr ...' 23 | + '\n $ bcash-utxo --tor LmyFirstKey KmyOtherKey ...' 24 | + '\n $ bcash-utxo --tor -f fileWithAddressesOrKeys.txt' 25 | + '\n\n README:', C.underline('https://github.com/shesek/bcash-instadump'), '(really, do!)\n')) 26 | 27 | .parse(process.argv) 28 | 29 | initArgs(args) 30 | const lookup = args.file ? readLines(args.file) : args.args 31 | if (!lookup.length) args.help() 32 | 33 | lookup.forEach(addrOrKey => 34 | loadUtxo(addrOrKey, args) 35 | .then(outs => { 36 | info('loaded', C.yellowBright(outs.length), 'utxos for', C.yellowBright(addrOrKey)) 37 | outs.length && console.log(outs.map(out => 38 | [ out.hash, out.vout, formatSat(out.value), addrOrKey ].join(',')).join('\n')) 39 | }) 40 | .catch(printErr) 41 | ) 42 | -------------------------------------------------------------------------------- /cli/common.js: -------------------------------------------------------------------------------- 1 | const Amount = require('bcoin/lib/btc/amount') 2 | , { readFileSync } = require('fs') 3 | , C = require('chalk') 4 | 5 | const MAXFEERATE = 2000 6 | 7 | const 8 | formatSat = sat => Amount.serialize(sat, 8) 9 | , toSat = btcs => Amount.parse(btcs, 8) 10 | 11 | , collector = map => (val, memo) => memo.concat([ map(val) ]) 12 | , parseInput = s => ((p=s.split(/[:,\s]/)) => ({ hash: p[0], index: +p[1], value: toSat(p[2]), key: p[3] }))() 13 | , parseOutput = s => ((p=s.split(/[:,\s]/)) => ({ address: p[0], value: p[1] === 'ALL' ? p[1] : toSat(p[1]) }))() 14 | 15 | , readLines = path => readFileSync(path).toString().split('\n').map(s => s.replace(/^\s+|\s+$/g, '')).filter(s => s.length) 16 | 17 | , info = (...text) => console.error(C.yellow('(info)'), ...text) 18 | , printErr = e => console.error(C.red('(error)'), e.message || e || '', e.response && (e.response.body && e.response.body.errors || e.response.text) || '') 19 | 20 | , initArgs = (args, expectProxy=true) => { 21 | if (args.tor) args.proxy = 'socks5h://127.0.0.1:9150' 22 | if (args.inputs) args.input = (args.input||[]).concat(readLines(args.inputs).map(parseInput)) 23 | if (args.keys) args.key = (args.key||[]).concat(readLines(args.keys)) 24 | if (!args.feerate) args.feerate = (Math.random()*50|0)+50 // 50 to 100 25 | 26 | if (expectProxy && !args.proxy && !args.noproxy) { 27 | printErr('no proxy was specified. set ' + C.yellowBright('--noproxy') + ' if you\'re sure about that, ' 28 | + 'or enable one with ' + C.yellowBright('--proxy') + '/' + C.yellowBright('--tor') + '.') 29 | process.exit(1) 30 | } else if (expectProxy) { 31 | info(args.noproxy ? 'not using a proxy' : 'using proxy: '+C.yellowBright(args.proxy)) 32 | } 33 | } 34 | 35 | , checkFee = tx => { 36 | if (tx.getRate(tx.view)/1000 > MAXFEERATE) { 37 | printErr('woah there! are you sure you want to pay '+Amount.btc(tx.getFee())+' BCH in fees? enable ' + C.yellowBright('--crazyfee') + ' if you are.') 38 | process.exit(1) 39 | } 40 | } 41 | 42 | process.on('uncaughtException', err => (printErr(err), process.exit(1))) 43 | 44 | module.exports = { formatSat, toSat, parseInput, parseOutput, collector, readLines, initArgs, checkFee, printErr, info } 45 | -------------------------------------------------------------------------------- /electrum-servers.json: -------------------------------------------------------------------------------- 1 | [ 2 | "tls://abc.vom-stausee.de:52002?anycert=1" 3 | , "tls://abc1.hsmiths.com:60002?anycert=1" 4 | , "tls://bch.arihanc.com:52002?anycert=1" 5 | , "tls://electroncash.cascharia.com:50002?anycert=1" 6 | ] 7 | -------------------------------------------------------------------------------- /lib/electrum.js: -------------------------------------------------------------------------------- 1 | const C = require('chalk') 2 | , readline = require('readline') 3 | , connect = require('./socket') 4 | , servers = require('../electrum-servers.json') 5 | 6 | const RE_TXID = /^[0-9a-f]{64}$/ 7 | 8 | // Electrum JSON-RPC 2.0 mini-client 9 | const Electrum = (server=randServer(), proxy) => { 10 | // @XXX creates a new socket for each call. not very efficient, 11 | // but easier than dealing with out-of-order responses (via `id`), 12 | // and we usually make just one request per execution anyway. 13 | const call = (method, ...params) => connect(server, proxy) 14 | .then(socket => new Promise((resolve, reject) => { 15 | const rl = readline.createInterface({ input: socket }) 16 | 17 | rl.once('line', d => (socket.end(), resolve(d.toString()))) 18 | 19 | socket.once('error', reject) 20 | socket.once('end', _ => reject('connection ended')) 21 | 22 | console.error(C.yellow('(info)'), 'electrum command:', C.yellowBright(method), '[', ...params.map(s => C.yellow(s)), '] to',C.yellowBright(server)) 23 | socket.write(JSON.stringify({ id: 1, method, params })+'\n') 24 | socket.resume() 25 | })) 26 | .then(JSON.parse) 27 | .then(r => r.error ? Promise.reject(r.error.message || r.error) : r.result) 28 | .catch(err => Promise.reject('Electrum server: '+err)) 29 | 30 | return { listunspent: addr => call('blockchain.address.listunspent', addr) 31 | , broadcast: rawtx => call('blockchain.transaction.broadcast', rawtx).then(parseBrReply) } 32 | } 33 | 34 | module.exports = Electrum 35 | 36 | const randServer = _ => servers[Math.random()*servers.length|0] 37 | 38 | // successful broadcasts return the txid in `resp.result`, 39 | // while failures return the error string in `result` without setting `error` (electrum bug?) 40 | // if it quacks like a txid, its a success. otherwise, its an error message. 41 | const parseBrReply = r => RE_TXID.test(r) ? r : Promise.reject(r) 42 | -------------------------------------------------------------------------------- /lib/make-tx.js: -------------------------------------------------------------------------------- 1 | const Address = require('bcoin/lib/primitives/address') 2 | , KeyRing = require('bcoin/lib/primitives/keyring') 3 | , Script = require('bcoin/lib/script/script') 4 | , MTX = require('bcoin/lib/primitives/mtx') 5 | , Coin = require('bcoin/lib/primitives/coin') 6 | , Amount = require('bcoin/lib/btc/amount') 7 | , uniq = xs => Object.keys(xs.reduce((o, v) => (o[v]=1,o), {})) // @XXX works on strings only 8 | 9 | require('./patch-bcoin-bcash') 10 | 11 | module.exports = (inputs, outputs, feerate) => { 12 | const tx = MTX.fromOptions({ version: 1 }) 13 | , coins = inputs.map(makeCoin) 14 | , keys = uniq(inputs.map(input => input.key)).map(key => KeyRing.fromSecret(key)) 15 | , isALL = (outputs.length == 1 && outputs[0].value == 'ALL') 16 | 17 | if (isALL) outputs[0].value = coins.reduce((t, c) => t + c.value, 0) // @XXX side effect 18 | 19 | coins .forEach(coin => tx.addCoin(coin)) 20 | outputs.forEach(output => tx.addOutput(output)) 21 | 22 | if (isALL && feerate) { 23 | // sign a cloned copy of the tx to figure out its size and fee, then substractFee() and re-sign 24 | const txTmp = tx.clone() 25 | txTmp.view = tx.view 26 | keys.forEach(key => txTmp.sign(key)) 27 | tx.subtractFee(txTmp.getMinFee(null, feerate*1000)) // we take feerate as sat/b, underlying bcoin uses sat/kb 28 | } 29 | 30 | keys.forEach(key => tx.sign(key)) 31 | 32 | return tx 33 | } 34 | 35 | const keyAddrScript = key => Script.fromAddress(KeyRing.fromSecret(key).getAddress()) 36 | , makeCoin = inv => Coin.fromOptions({ hash: revHex(inv.hash), index: inv.index, value: inv.value, script: keyAddrScript(inv.key) }) 37 | , revHex = hex => hex.match(/../g).reverse().join('') 38 | -------------------------------------------------------------------------------- /lib/patch-bcoin-bcash.js: -------------------------------------------------------------------------------- 1 | const TX = require('bcoin/lib/primitives/tx') 2 | const MTX = require('bcoin/lib/primitives/mtx') 3 | 4 | const SIGHASH_FORKID = 0x40 5 | , SIGHASH_ALL = 0x01 6 | , SEGWIT_VER = 1 7 | 8 | // Patch bcoin with bcash compatibility: 9 | // 1. Flip the FORKID bit in the sighash type 10 | // 2. Always use segwit's sighash digest algorithm (BIP 143) 11 | function patch (proto, fn=proto.signature) { 12 | proto.signature = function(index, prev, value, key, type=SIGHASH_ALL, version) { 13 | return fn.call(this, index, prev, value, key, type|SIGHASH_FORKID, SEGWIT_VER) 14 | } 15 | } 16 | 17 | // commit 8593bd9410a in bcoin moved MTX::signature to TX::signature. 18 | // instadump currently uses an old bcoin release with MTX::signature 19 | // (for compatibility with nodejs 6.x), but it should still ensure that 20 | // it works properly on newer bcoin releases (without this, we'll be 21 | // generating bitcoin-compatible transactions that might move BTC!) 22 | TX.prototype.signature && patch(TX.prototype) 23 | MTX.prototype.signature && patch(MTX.prototype) 24 | -------------------------------------------------------------------------------- /lib/shapeshift.js: -------------------------------------------------------------------------------- 1 | const request = require('superagent-proxy')(require('superagent')) 2 | 3 | const refid = '5a5d6de73521ed45e05bedbb88f666504f582d5149835da3753357a71b38dea3feb810d0d4f80f66f39cf2e81a0fc921b98072d97affdf2ab2c9205b195b2d42' 4 | 5 | const ShapeShift = ({ noreferral, proxy }) => { 6 | const proxify = r => proxy ? r.proxy(proxy) : r 7 | , apiKey = !noreferral ? refid : undefined 8 | 9 | return { 10 | marketinfo: pair => 11 | proxify(request.get('https://shapeshift.io/marketinfo/'+pair)) 12 | .set('User-Agent', '') 13 | .then(res => !res.body.error && res.body || Promise.reject(res.body.error || 'cannot fetch market info')) 14 | 15 | , openOrder: (pair, depositAmount, returnAddress, withdrawal/*addr*/) => 16 | proxify(request.post('https://shapeshift.io/sendamount')) 17 | .set('User-Agent', '') 18 | .type('json').send({ pair, depositAmount, withdrawal, returnAddress, apiKey }) 19 | .then(res => !res.body.error && res.body.success || Promise.reject(res.body.error || 'cannot create order')) 20 | .then(order => Object.assign({}, order, { url: orderURL(order.orderId) })) 21 | } 22 | } 23 | 24 | module.exports = ShapeShift 25 | 26 | const orderURL = id => `https://shapeshift.io/#/status/${ encodeURIComponent(id) }` 27 | -------------------------------------------------------------------------------- /lib/socket.js: -------------------------------------------------------------------------------- 1 | const Socks = require('socks') 2 | , url = require('url') 3 | , net = require('net') 4 | , tls = require('tls') 5 | 6 | const typeMap = { socks4: 4, socks4a: 5, socks5: 5, socks5h: 5, socks: 5 } 7 | , sockMap = { tls: tls.TLSSocket, tcp: net.Socket, socket: net.Socket } 8 | 9 | module.exports = (target, proxy) => 10 | (proxy ? proxyConnect : directConnect)(parseUri(target), proxy && parseUri(proxy)) 11 | 12 | const 13 | parseUri = (uri, p=url.parse(uri, true)) => ({ host: p.hostname, port: +p.port, proto: p.protocol.slice(0, -1), opt: p.query }) 14 | 15 | , directConnect = target => new Promise((resolve, reject) => { 16 | if (!sockMap[target.proto]) throw new Error(`invalid proto "${target.proto}" for server "${target.host}", should be: "tls" or "tcp"`) 17 | const socket = new sockMap[target.proto] 18 | socket.once('connect', _ => resolve(socket)) 19 | socket.once('error', reject) 20 | socket.once('end', _ => reject('connection ended')) 21 | socket.connect(target.port, target.host, target.proto == 'tls' ? { rejectUnauthorized: !target.opt.anycert} : {}) 22 | }) 23 | 24 | , proxyConnect = (target, proxy) => { 25 | if (!typeMap[proxy.proto]) throw new Error(`invalid proto "${proxy.proto}" for proxy "${proxy.host}", should be: "socks4", "socks4a", "socks5" or "socks5h"`) 26 | return (target.proto == 'tls' ? proxyConnectTls : proxyConnectTcp)(target, proxy) 27 | } 28 | 29 | , proxyConnectTcp = (target, proxy) => new Promise((resolve, reject) => 30 | Socks.createConnection({ target, proxy: Object.assign({}, proxy, { type: typeMap[proxy.proto] }) } 31 | , (err, socket) => err ? reject(err) : resolve(socket))) 32 | 33 | , proxyConnectTls = (target, proxy) => proxyConnectTcp(target, proxy) 34 | .then(encSocket => new Promise((resolve, reject) => { 35 | const plnSocket = tls.connect({ socket: encSocket, servername: target.host, rejectUnauthorized: !target.opt.anycert }) 36 | plnSocket.once('secureConnect', _ => resolve(plnSocket)) 37 | plnSocket.once('error', reject) 38 | })) 39 | -------------------------------------------------------------------------------- /lib/utxo.js: -------------------------------------------------------------------------------- 1 | const KeyRing = require('bcoin/lib/primitives/keyring') 2 | , Address = require('bcoin/lib/primitives/address') 3 | , Electrum = require('./electrum') 4 | 5 | const loadUtxo = (addrOrKey, { electrum, proxy }, retries=3) => 6 | Electrum(electrum, proxy).listunspent(toAddr(addrOrKey)) 7 | .then(utxos => utxos.map(u => ({ hash: u.tx_hash, vout: u.tx_pos, value: u.value }))) 8 | .catch(err => --retries ? loadUtxo(addrOrKey, { electrum, proxy }, retries) : Promise.reject(err)) 9 | 10 | const keysUtxo = (keys, opt) => 11 | Promise.all(keys.map(key => 12 | loadUtxo(key, opt).then(xs => 13 | xs.map(x => Object.assign({}, x, { key }))) 14 | )).then(keysOut => [].concat(...keysOut)) 15 | 16 | const toAddr = str => { 17 | try { return KeyRing.fromSecret(str).getAddress().toString() } catch (_) {} 18 | try { return Address.fromBase58(str).toString() } catch (_) {} 19 | throw new Error(`invalid addressOrKey: ${ str }`) 20 | } 21 | 22 | module.exports = loadUtxo 23 | loadUtxo.loadUtxo = loadUtxo 24 | loadUtxo.keysUtxo = keysUtxo 25 | -------------------------------------------------------------------------------- /npm-shrinkwrap.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bcash-instadump", 3 | "version": "0.4.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "agent-base": { 8 | "version": "2.1.1", 9 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-2.1.1.tgz", 10 | "integrity": "sha1-1t4Q1a9hMtW9aSQn1G/FOFOQlMc=", 11 | "requires": { 12 | "extend": "3.0.1", 13 | "semver": "5.0.3" 14 | } 15 | }, 16 | "ansi-escapes": { 17 | "version": "2.0.0", 18 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-2.0.0.tgz", 19 | "integrity": "sha1-W65SvkJIeN2Xg+iRDj/Cki6DyBs=" 20 | }, 21 | "ansi-regex": { 22 | "version": "3.0.0", 23 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 24 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 25 | }, 26 | "ansi-styles": { 27 | "version": "3.2.0", 28 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 29 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 30 | "requires": { 31 | "color-convert": "1.9.0" 32 | } 33 | }, 34 | "ast-types": { 35 | "version": "0.9.12", 36 | "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.9.12.tgz", 37 | "integrity": "sha1-sTYwDWcCZiWuFTJpgsqZGOXbc8k=" 38 | }, 39 | "asynckit": { 40 | "version": "0.4.0", 41 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 42 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 43 | }, 44 | "bcoin": { 45 | "version": "1.0.0-beta.12", 46 | "resolved": "https://registry.npmjs.org/bcoin/-/bcoin-1.0.0-beta.12.tgz", 47 | "integrity": "sha1-hb+4F/VjDlnKsLeHv51DaPwSRsQ=", 48 | "requires": { 49 | "bn.js": "4.11.6", 50 | "elliptic": "6.3.2" 51 | } 52 | }, 53 | "bn.js": { 54 | "version": "4.11.6", 55 | "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.6.tgz", 56 | "integrity": "sha1-UzRK2xRhehP26N0s4okF0cC6MhU=" 57 | }, 58 | "brorand": { 59 | "version": "1.1.0", 60 | "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", 61 | "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" 62 | }, 63 | "bytes": { 64 | "version": "2.5.0", 65 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-2.5.0.tgz", 66 | "integrity": "sha1-TJQj6i0lLCcMQbK97+/5u2tiwGo=" 67 | }, 68 | "chalk": { 69 | "version": "2.1.0", 70 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.1.0.tgz", 71 | "integrity": "sha512-LUHGS/dge4ujbXMJrnihYMcL4AoOweGnw9Tp3kQuqy1Kx5c1qKjqvMJZ6nVJPMWJtKCTN72ZogH3oeSO9g9rXQ==", 72 | "requires": { 73 | "ansi-styles": "3.2.0", 74 | "escape-string-regexp": "1.0.5", 75 | "supports-color": "4.2.1" 76 | } 77 | }, 78 | "cli-cursor": { 79 | "version": "2.1.0", 80 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 81 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 82 | "requires": { 83 | "restore-cursor": "2.0.0" 84 | } 85 | }, 86 | "cli-width": { 87 | "version": "2.1.0", 88 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.1.0.tgz", 89 | "integrity": "sha1-sjTKIJsp72b8UY2bmNWEewDt8Ao=" 90 | }, 91 | "co": { 92 | "version": "4.6.0", 93 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 94 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 95 | }, 96 | "color-convert": { 97 | "version": "1.9.0", 98 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", 99 | "integrity": "sha1-Gsz5fdc5uYO/mU1W/sj5WFNkG3o=", 100 | "requires": { 101 | "color-name": "1.1.3" 102 | } 103 | }, 104 | "color-name": { 105 | "version": "1.1.3", 106 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 107 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 108 | }, 109 | "combined-stream": { 110 | "version": "1.0.5", 111 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 112 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 113 | "requires": { 114 | "delayed-stream": "1.0.0" 115 | } 116 | }, 117 | "commander": { 118 | "version": "2.11.0", 119 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 120 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==" 121 | }, 122 | "component-emitter": { 123 | "version": "1.2.1", 124 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 125 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=" 126 | }, 127 | "cookiejar": { 128 | "version": "2.1.1", 129 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.1.tgz", 130 | "integrity": "sha1-Qa1XsbVVlR7BcUEqgZQrHoIA00o=" 131 | }, 132 | "core-util-is": { 133 | "version": "1.0.2", 134 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 135 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 136 | }, 137 | "data-uri-to-buffer": { 138 | "version": "1.2.0", 139 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-1.2.0.tgz", 140 | "integrity": "sha512-vKQ9DTQPN1FLYiiEEOQ6IBGFqvjCa5rSK3cWMy/Nespm5d/x3dGFT9UBZnkLxCwua/IXBi2TYnwTEpsOvhC4UQ==" 141 | }, 142 | "debug": { 143 | "version": "2.6.8", 144 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", 145 | "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", 146 | "requires": { 147 | "ms": "2.0.0" 148 | } 149 | }, 150 | "deep-is": { 151 | "version": "0.1.3", 152 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 153 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" 154 | }, 155 | "degenerator": { 156 | "version": "1.0.4", 157 | "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-1.0.4.tgz", 158 | "integrity": "sha1-/PSQo37OJmRk2cxDGrmMWBnO0JU=", 159 | "requires": { 160 | "ast-types": "0.9.12", 161 | "escodegen": "1.8.1", 162 | "esprima": "3.1.3" 163 | } 164 | }, 165 | "delayed-stream": { 166 | "version": "1.0.0", 167 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 168 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 169 | }, 170 | "depd": { 171 | "version": "1.1.0", 172 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", 173 | "integrity": "sha1-4b2Cxqq2ztlluXuIsX7T5SjKGMM=" 174 | }, 175 | "elliptic": { 176 | "version": "6.3.2", 177 | "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.3.2.tgz", 178 | "integrity": "sha1-5MgeCCnPCmWrcOmYuCMnI7XBvEg=", 179 | "requires": { 180 | "bn.js": "4.11.6", 181 | "brorand": "1.1.0", 182 | "hash.js": "1.1.3", 183 | "inherits": "2.0.3" 184 | } 185 | }, 186 | "es6-promise": { 187 | "version": "4.1.1", 188 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.1.1.tgz", 189 | "integrity": "sha512-OaU1hHjgJf+b0NzsxCg7NdIYERD6Hy/PEmFLTjw+b65scuisG3Kt4QoTvJ66BBkPZ581gr0kpoVzKnxniM8nng==" 190 | }, 191 | "es6-promisify": { 192 | "version": "5.0.0", 193 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 194 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 195 | "requires": { 196 | "es6-promise": "4.1.1" 197 | } 198 | }, 199 | "escape-string-regexp": { 200 | "version": "1.0.5", 201 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 202 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 203 | }, 204 | "escodegen": { 205 | "version": "1.8.1", 206 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", 207 | "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", 208 | "requires": { 209 | "esprima": "2.7.3", 210 | "estraverse": "1.9.3", 211 | "esutils": "2.0.2", 212 | "optionator": "0.8.2" 213 | }, 214 | "dependencies": { 215 | "esprima": { 216 | "version": "2.7.3", 217 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", 218 | "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=" 219 | } 220 | } 221 | }, 222 | "esprima": { 223 | "version": "3.1.3", 224 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", 225 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=" 226 | }, 227 | "estraverse": { 228 | "version": "1.9.3", 229 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", 230 | "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=" 231 | }, 232 | "esutils": { 233 | "version": "2.0.2", 234 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 235 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" 236 | }, 237 | "extend": { 238 | "version": "3.0.1", 239 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 240 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" 241 | }, 242 | "external-editor": { 243 | "version": "2.0.4", 244 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.0.4.tgz", 245 | "integrity": "sha1-HtkZnanL/i7y96MbL96LDRI2iXI=", 246 | "requires": { 247 | "iconv-lite": "0.4.18", 248 | "jschardet": "1.5.1", 249 | "tmp": "0.0.31" 250 | } 251 | }, 252 | "fast-levenshtein": { 253 | "version": "2.0.6", 254 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 255 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" 256 | }, 257 | "figures": { 258 | "version": "2.0.0", 259 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 260 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 261 | "requires": { 262 | "escape-string-regexp": "1.0.5" 263 | } 264 | }, 265 | "file-uri-to-path": { 266 | "version": "1.0.0", 267 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 268 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==" 269 | }, 270 | "form-data": { 271 | "version": "2.2.0", 272 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.2.0.tgz", 273 | "integrity": "sha1-ml47kpX5gLJiPPZPojixTOvKcHs=", 274 | "requires": { 275 | "asynckit": "0.4.0", 276 | "combined-stream": "1.0.5", 277 | "mime-types": "2.1.16" 278 | } 279 | }, 280 | "formidable": { 281 | "version": "1.1.1", 282 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.1.1.tgz", 283 | "integrity": "sha1-lriIb3w8NQi5Mta9cMTTqI818ak=" 284 | }, 285 | "ftp": { 286 | "version": "0.3.10", 287 | "resolved": "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz", 288 | "integrity": "sha1-kZfYYa2BQvPmPVqDv+TFn3MwiF0=", 289 | "requires": { 290 | "readable-stream": "1.1.14", 291 | "xregexp": "2.0.0" 292 | }, 293 | "dependencies": { 294 | "isarray": { 295 | "version": "0.0.1", 296 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 297 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 298 | }, 299 | "readable-stream": { 300 | "version": "1.1.14", 301 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 302 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 303 | "requires": { 304 | "core-util-is": "1.0.2", 305 | "inherits": "2.0.3", 306 | "isarray": "0.0.1", 307 | "string_decoder": "0.10.31" 308 | } 309 | }, 310 | "string_decoder": { 311 | "version": "0.10.31", 312 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 313 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 314 | } 315 | } 316 | }, 317 | "get-uri": { 318 | "version": "2.0.1", 319 | "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-2.0.1.tgz", 320 | "integrity": "sha512-7aelVrYqCLuVjq2kEKRTH8fXPTC0xKTkM+G7UlFkEwCXY3sFbSxvY375JoFowOAYbkaU47SrBvOefUlLZZ+6QA==", 321 | "requires": { 322 | "data-uri-to-buffer": "1.2.0", 323 | "debug": "2.6.8", 324 | "extend": "3.0.1", 325 | "file-uri-to-path": "1.0.0", 326 | "ftp": "0.3.10", 327 | "readable-stream": "2.3.3" 328 | } 329 | }, 330 | "has-flag": { 331 | "version": "2.0.0", 332 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 333 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=" 334 | }, 335 | "hash.js": { 336 | "version": "1.1.3", 337 | "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.3.tgz", 338 | "integrity": "sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA==", 339 | "requires": { 340 | "inherits": "2.0.3", 341 | "minimalistic-assert": "1.0.0" 342 | } 343 | }, 344 | "http-errors": { 345 | "version": "1.6.1", 346 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.1.tgz", 347 | "integrity": "sha1-X4uO2YrKVFZWv1cplzh/kEpyIlc=", 348 | "requires": { 349 | "depd": "1.1.0", 350 | "inherits": "2.0.3", 351 | "setprototypeof": "1.0.3", 352 | "statuses": "1.3.1" 353 | } 354 | }, 355 | "http-proxy-agent": { 356 | "version": "1.0.0", 357 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-1.0.0.tgz", 358 | "integrity": "sha1-zBzjjkU7+YSg93AtLdWcc9CBKEo=", 359 | "requires": { 360 | "agent-base": "2.1.1", 361 | "debug": "2.6.8", 362 | "extend": "3.0.1" 363 | } 364 | }, 365 | "https-proxy-agent": { 366 | "version": "1.0.0", 367 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-1.0.0.tgz", 368 | "integrity": "sha1-NffabEjOTdv6JkiRrFk+5f+GceY=", 369 | "requires": { 370 | "agent-base": "2.1.1", 371 | "debug": "2.6.8", 372 | "extend": "3.0.1" 373 | } 374 | }, 375 | "iconv-lite": { 376 | "version": "0.4.18", 377 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.18.tgz", 378 | "integrity": "sha512-sr1ZQph3UwHTR0XftSbK85OvBbxe/abLGzEnPENCQwmHf7sck8Oyu4ob3LgBxWWxRoM+QszeUyl7jbqapu2TqA==" 379 | }, 380 | "inherits": { 381 | "version": "2.0.3", 382 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 383 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 384 | }, 385 | "inquirer": { 386 | "version": "3.2.1", 387 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.2.1.tgz", 388 | "integrity": "sha512-QgW3eiPN8gpj/K5vVpHADJJgrrF0ho/dZGylikGX7iqAdRgC9FVKYKWFLx6hZDBFcOLEoSqINYrVPeFAeG/PdA==", 389 | "requires": { 390 | "ansi-escapes": "2.0.0", 391 | "chalk": "2.1.0", 392 | "cli-cursor": "2.1.0", 393 | "cli-width": "2.1.0", 394 | "external-editor": "2.0.4", 395 | "figures": "2.0.0", 396 | "lodash": "4.17.4", 397 | "mute-stream": "0.0.7", 398 | "run-async": "2.3.0", 399 | "rx-lite": "4.0.8", 400 | "rx-lite-aggregates": "4.0.8", 401 | "string-width": "2.1.1", 402 | "strip-ansi": "4.0.0", 403 | "through": "2.3.8" 404 | } 405 | }, 406 | "ip": { 407 | "version": "1.1.5", 408 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 409 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" 410 | }, 411 | "is-fullwidth-code-point": { 412 | "version": "2.0.0", 413 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 414 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 415 | }, 416 | "is-promise": { 417 | "version": "2.1.0", 418 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 419 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 420 | }, 421 | "isarray": { 422 | "version": "1.0.0", 423 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 424 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 425 | }, 426 | "jschardet": { 427 | "version": "1.5.1", 428 | "resolved": "https://registry.npmjs.org/jschardet/-/jschardet-1.5.1.tgz", 429 | "integrity": "sha512-vE2hT1D0HLZCLLclfBSfkfTTedhVj0fubHpJBHKwwUWX0nSbhPAfk+SG9rTX95BYNmau8rGFfCeaT6T5OW1C2A==" 430 | }, 431 | "levn": { 432 | "version": "0.3.0", 433 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 434 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 435 | "requires": { 436 | "prelude-ls": "1.1.2", 437 | "type-check": "0.3.2" 438 | } 439 | }, 440 | "lodash": { 441 | "version": "4.17.4", 442 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 443 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 444 | }, 445 | "lru-cache": { 446 | "version": "2.6.5", 447 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-2.6.5.tgz", 448 | "integrity": "sha1-5W1jVBSO3o13B7WNFDIg/QjfD9U=" 449 | }, 450 | "methods": { 451 | "version": "1.1.2", 452 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 453 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 454 | }, 455 | "mime": { 456 | "version": "1.3.6", 457 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.3.6.tgz", 458 | "integrity": "sha1-WR2E02U6awtKO5343lqoEI5y5eA=" 459 | }, 460 | "mime-db": { 461 | "version": "1.29.0", 462 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.29.0.tgz", 463 | "integrity": "sha1-SNJtI1WJZRcErFkWygYAGRQmaHg=" 464 | }, 465 | "mime-types": { 466 | "version": "2.1.16", 467 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.16.tgz", 468 | "integrity": "sha1-K4WKUuXs1RbbiXrCvodIeDBpjiM=", 469 | "requires": { 470 | "mime-db": "1.29.0" 471 | } 472 | }, 473 | "mimic-fn": { 474 | "version": "1.1.0", 475 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", 476 | "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=" 477 | }, 478 | "minimalistic-assert": { 479 | "version": "1.0.0", 480 | "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.0.tgz", 481 | "integrity": "sha1-cCvi3aazf0g2vLP121ZkG2Sh09M=" 482 | }, 483 | "ms": { 484 | "version": "2.0.0", 485 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 486 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 487 | }, 488 | "mute-stream": { 489 | "version": "0.0.7", 490 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 491 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=" 492 | }, 493 | "netmask": { 494 | "version": "1.0.6", 495 | "resolved": "https://registry.npmjs.org/netmask/-/netmask-1.0.6.tgz", 496 | "integrity": "sha1-ICl+idhvb2QA8lDZ9Pa0wZRfzTU=" 497 | }, 498 | "onetime": { 499 | "version": "2.0.1", 500 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 501 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 502 | "requires": { 503 | "mimic-fn": "1.1.0" 504 | } 505 | }, 506 | "optionator": { 507 | "version": "0.8.2", 508 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 509 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 510 | "requires": { 511 | "deep-is": "0.1.3", 512 | "fast-levenshtein": "2.0.6", 513 | "levn": "0.3.0", 514 | "prelude-ls": "1.1.2", 515 | "type-check": "0.3.2", 516 | "wordwrap": "1.0.0" 517 | } 518 | }, 519 | "os-tmpdir": { 520 | "version": "1.0.2", 521 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 522 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 523 | }, 524 | "pac-proxy-agent": { 525 | "version": "2.0.0", 526 | "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-2.0.0.tgz", 527 | "integrity": "sha512-t57UiJpi5mFLTvjheC1SNSwIhml3+ElNOj69iRrydtQXZJr8VIFYSDtyPi/3ZysA62kD2dmww6pDlzk0VaONZg==", 528 | "requires": { 529 | "agent-base": "2.1.1", 530 | "debug": "2.6.8", 531 | "get-uri": "2.0.1", 532 | "http-proxy-agent": "1.0.0", 533 | "https-proxy-agent": "1.0.0", 534 | "pac-resolver": "3.0.0", 535 | "raw-body": "2.3.0", 536 | "socks-proxy-agent": "3.0.0" 537 | }, 538 | "dependencies": { 539 | "socks-proxy-agent": { 540 | "version": "3.0.0", 541 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-3.0.0.tgz", 542 | "integrity": "sha512-YJcT+SNNBgFoK/NpO20PChz0VnBOhkjG3X10BwlrYujd0NZlSsH1jbxSQ1S0njt3sOvzwQ2PvGqqUIvP4rNk/w==", 543 | "requires": { 544 | "agent-base": "4.1.1", 545 | "socks": "1.1.10" 546 | }, 547 | "dependencies": { 548 | "agent-base": { 549 | "version": "4.1.1", 550 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.1.1.tgz", 551 | "integrity": "sha512-yWGUUmCZD/33IRjG2It94PzixT8lX+47Uq8fjmd0cgQWITCMrJuXFaVIMnGDmDnZGGKAGdwTx8UGeU8lMR2urA==", 552 | "requires": { 553 | "es6-promisify": "5.0.0" 554 | } 555 | } 556 | } 557 | } 558 | } 559 | }, 560 | "pac-resolver": { 561 | "version": "3.0.0", 562 | "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-3.0.0.tgz", 563 | "integrity": "sha512-tcc38bsjuE3XZ5+4vP96OfhOugrX+JcnpUbhfuc4LuXBLQhoTthOstZeoQJBDnQUDYzYmdImKsbz0xSl1/9qeA==", 564 | "requires": { 565 | "co": "4.6.0", 566 | "degenerator": "1.0.4", 567 | "ip": "1.1.5", 568 | "netmask": "1.0.6", 569 | "thunkify": "2.1.2" 570 | } 571 | }, 572 | "prelude-ls": { 573 | "version": "1.1.2", 574 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 575 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" 576 | }, 577 | "process-nextick-args": { 578 | "version": "1.0.7", 579 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 580 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 581 | }, 582 | "proxy-agent": { 583 | "version": "2.1.0", 584 | "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-2.1.0.tgz", 585 | "integrity": "sha512-I23qaUnXmU/ItpXWQcMj9wMcZQTXnJNI7nakSR+q95Iht8H0+w3dCgTJdfnOQqOCX1FZwKLSgurCyEt11LM6OA==", 586 | "requires": { 587 | "agent-base": "2.1.1", 588 | "debug": "2.6.8", 589 | "extend": "3.0.1", 590 | "http-proxy-agent": "1.0.0", 591 | "https-proxy-agent": "1.0.0", 592 | "lru-cache": "2.6.5", 593 | "pac-proxy-agent": "2.0.0", 594 | "socks-proxy-agent": "2.1.1" 595 | } 596 | }, 597 | "qs": { 598 | "version": "6.5.0", 599 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.0.tgz", 600 | "integrity": "sha512-fjVFjW9yhqMhVGwRExCXLhJKrLlkYSaxNWdyc9rmHlrVZbk35YHH312dFd7191uQeXkI3mKLZTIbSvIeFwFemg==" 601 | }, 602 | "raw-body": { 603 | "version": "2.3.0", 604 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.0.tgz", 605 | "integrity": "sha1-95zhrKyrpbY2LTNFTXhdcSn0vGc=", 606 | "requires": { 607 | "bytes": "2.5.0", 608 | "http-errors": "1.6.1", 609 | "iconv-lite": "0.4.18", 610 | "unpipe": "1.0.0" 611 | } 612 | }, 613 | "readable-stream": { 614 | "version": "2.3.3", 615 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 616 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 617 | "requires": { 618 | "core-util-is": "1.0.2", 619 | "inherits": "2.0.3", 620 | "isarray": "1.0.0", 621 | "process-nextick-args": "1.0.7", 622 | "safe-buffer": "5.1.1", 623 | "string_decoder": "1.0.3", 624 | "util-deprecate": "1.0.2" 625 | } 626 | }, 627 | "restore-cursor": { 628 | "version": "2.0.0", 629 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 630 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 631 | "requires": { 632 | "onetime": "2.0.1", 633 | "signal-exit": "3.0.2" 634 | } 635 | }, 636 | "run-async": { 637 | "version": "2.3.0", 638 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 639 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 640 | "requires": { 641 | "is-promise": "2.1.0" 642 | } 643 | }, 644 | "rx-lite": { 645 | "version": "4.0.8", 646 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", 647 | "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=" 648 | }, 649 | "rx-lite-aggregates": { 650 | "version": "4.0.8", 651 | "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", 652 | "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", 653 | "requires": { 654 | "rx-lite": "4.0.8" 655 | } 656 | }, 657 | "safe-buffer": { 658 | "version": "5.1.1", 659 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 660 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 661 | }, 662 | "semver": { 663 | "version": "5.0.3", 664 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.0.3.tgz", 665 | "integrity": "sha1-d0Zt5YnNXTyV8TiqeLxWmjy10no=" 666 | }, 667 | "setprototypeof": { 668 | "version": "1.0.3", 669 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 670 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 671 | }, 672 | "signal-exit": { 673 | "version": "3.0.2", 674 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 675 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 676 | }, 677 | "smart-buffer": { 678 | "version": "1.1.15", 679 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-1.1.15.tgz", 680 | "integrity": "sha1-fxFLW2X6s+KjWqd1uxLw0cZJvxY=" 681 | }, 682 | "socks": { 683 | "version": "1.1.10", 684 | "resolved": "https://registry.npmjs.org/socks/-/socks-1.1.10.tgz", 685 | "integrity": "sha1-W4t/x8jzQcU+0FbpKbe/Tei6e1o=", 686 | "requires": { 687 | "ip": "1.1.5", 688 | "smart-buffer": "1.1.15" 689 | } 690 | }, 691 | "socks-proxy-agent": { 692 | "version": "2.1.1", 693 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-2.1.1.tgz", 694 | "integrity": "sha512-sFtmYqdUK5dAMh85H0LEVFUCO7OhJJe1/z2x/Z6mxp3s7/QPf1RkZmpZy+BpuU0bEjcV9npqKjq9Y3kwFUjnxw==", 695 | "requires": { 696 | "agent-base": "2.1.1", 697 | "extend": "3.0.1", 698 | "socks": "1.1.10" 699 | } 700 | }, 701 | "statuses": { 702 | "version": "1.3.1", 703 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 704 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 705 | }, 706 | "string_decoder": { 707 | "version": "1.0.3", 708 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 709 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 710 | "requires": { 711 | "safe-buffer": "5.1.1" 712 | } 713 | }, 714 | "string-width": { 715 | "version": "2.1.1", 716 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 717 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 718 | "requires": { 719 | "is-fullwidth-code-point": "2.0.0", 720 | "strip-ansi": "4.0.0" 721 | } 722 | }, 723 | "strip-ansi": { 724 | "version": "4.0.0", 725 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 726 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 727 | "requires": { 728 | "ansi-regex": "3.0.0" 729 | } 730 | }, 731 | "superagent": { 732 | "version": "3.5.2", 733 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-3.5.2.tgz", 734 | "integrity": "sha1-M2GjlxVnUEw1EGOr6q4PqiPb8/g=", 735 | "requires": { 736 | "component-emitter": "1.2.1", 737 | "cookiejar": "2.1.1", 738 | "debug": "2.6.8", 739 | "extend": "3.0.1", 740 | "form-data": "2.2.0", 741 | "formidable": "1.1.1", 742 | "methods": "1.1.2", 743 | "mime": "1.3.6", 744 | "qs": "6.5.0", 745 | "readable-stream": "2.3.3" 746 | } 747 | }, 748 | "superagent-proxy": { 749 | "version": "1.0.2", 750 | "resolved": "https://registry.npmjs.org/superagent-proxy/-/superagent-proxy-1.0.2.tgz", 751 | "integrity": "sha1-ktNmBXj2GO1DqCz4yseZ/ik4ui0=", 752 | "requires": { 753 | "debug": "2.6.8", 754 | "proxy-agent": "2.1.0" 755 | } 756 | }, 757 | "supports-color": { 758 | "version": "4.2.1", 759 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.2.1.tgz", 760 | "integrity": "sha512-qxzYsob3yv6U+xMzPrv170y8AwGP7i74g+pbixCfD6rgso8BscLT2qXIuz6TpOaiJZ3mFgT5O9lyT9nMU4LfaA==", 761 | "requires": { 762 | "has-flag": "2.0.0" 763 | } 764 | }, 765 | "through": { 766 | "version": "2.3.8", 767 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 768 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 769 | }, 770 | "thunkify": { 771 | "version": "2.1.2", 772 | "resolved": "https://registry.npmjs.org/thunkify/-/thunkify-2.1.2.tgz", 773 | "integrity": "sha1-+qDp0jDFGsyVyhOjYawFyn4EVT0=" 774 | }, 775 | "tmp": { 776 | "version": "0.0.31", 777 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.31.tgz", 778 | "integrity": "sha1-jzirlDjhcxXl29izZX6L+yd65Kc=", 779 | "requires": { 780 | "os-tmpdir": "1.0.2" 781 | } 782 | }, 783 | "type-check": { 784 | "version": "0.3.2", 785 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 786 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 787 | "requires": { 788 | "prelude-ls": "1.1.2" 789 | } 790 | }, 791 | "unpipe": { 792 | "version": "1.0.0", 793 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 794 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 795 | }, 796 | "util-deprecate": { 797 | "version": "1.0.2", 798 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 799 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 800 | }, 801 | "wordwrap": { 802 | "version": "1.0.0", 803 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 804 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" 805 | }, 806 | "xregexp": { 807 | "version": "2.0.0", 808 | "resolved": "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz", 809 | "integrity": "sha1-UqY+VsoLhKfzpfPWGHLxJq16WUM=" 810 | } 811 | } 812 | } 813 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bcash-instadump", 3 | "version": "0.4.0", 4 | "description": "CLI tools for insta-dumping bcash in exchange for bitcoins (via ShapeShift), creating bcash-compatible transactions, and more.", 5 | "author": "Nadav Ivgi ", 6 | "license": "GPL-3.0", 7 | "keywords": [ 8 | "bitcoin", 9 | "bcash", 10 | "bch", 11 | "bcc", 12 | "dump", 13 | "shapeshift" 14 | ], 15 | "repository": "https://github.com/shesek/bcash-instadump", 16 | "bin": { 17 | "bcash-instadump": "./cli/bcash-instadump.js", 18 | "bcash-tx": "./cli/bcash-tx.js", 19 | "bcash-utxo": "./cli/bcash-utxo.js", 20 | "bcash-broadcast": "./cli/bcash-broadcast.js" 21 | }, 22 | "dependencies": { 23 | "bcoin": "1.0.0-beta.12", 24 | "chalk": "2.1.0", 25 | "commander": "2.11.0", 26 | "inquirer": "3.2.1", 27 | "socks": "1.1.10", 28 | "superagent": "3.5.2", 29 | "superagent-proxy": "1.0.2" 30 | }, 31 | "engines": { 32 | "node": ">=6.0.0" 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /screenshot.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/shesek/bcash-instadump/e73ef58416956cc9cb0d502d921bcaf9ed1cc117/screenshot.png -------------------------------------------------------------------------------- /utility/tor-newnym.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | [ "$#" -eq 2 ] || { echo "usage: $0 " >&2; exit 1; } 4 | 5 | echo -ne 'AUTHENTICATE "'$2'"\r\nSIGNAL NEWNYM\r\nQUIT\r\n' | nc localhost $1 > /dev/null 6 | --------------------------------------------------------------------------------