Clean up additional documents
This commit is contained in:
parent
3f3fd922c8
commit
874d22d060
6 changed files with 249 additions and 55 deletions
|
@ -7,6 +7,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- Sending transactions to transparent addresses, removing the memo and using the `AllowRevealedRecipients` privacy policy.
|
||||||
|
|
||||||
## [0.3.1.0]
|
## [0.3.1.0]
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
191
LICENSE
191
LICENSE
|
@ -1,23 +1,178 @@
|
||||||
[The MIT License (MIT)][]
|
Copyright (c) 2022 Vergara Technologies
|
||||||
|
|
||||||
Copyright (c) 2022 Rene Vergara
|
=======================================================
|
||||||
|
Bootstrap Open Source Licence ("BOSL") v. 1.0
|
||||||
|
=======================================================
|
||||||
|
This Bootstrap Open Source Licence (the "License") applies to any original work
|
||||||
|
of authorship (the "Original Work") whose owner (the "Licensor") has placed the
|
||||||
|
following licensing notice adjacent to the copyright notice for the Original
|
||||||
|
Work:
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
*Licensed under the Bootstrap Open Source Licence version 1.0*
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
|
||||||
the Software without restriction, including without limitation the rights to
|
|
||||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
||||||
of the Software, and to permit persons to whom the Software is furnished to do
|
|
||||||
so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
1. **Grant of Copyright License.** Licensor grants You a worldwide,
|
||||||
copies or substantial portions of the Software.
|
royalty-free, non-exclusive, sublicensable license, for the duration of the
|
||||||
|
copyright in the Original Work, to do the following:
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
a. to reproduce the Original Work in copies, either alone or as part of
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
a collective work;
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE.
|
|
||||||
|
|
||||||
[The MIT License (MIT)]: https://opensource.org/licenses/MIT
|
b. to translate, adapt, alter, transform, modify, or arrange the
|
||||||
|
Original Work, thereby creating derivative works ("Derivative Works")
|
||||||
|
based upon the Original Work;
|
||||||
|
|
||||||
|
c. to distribute or communicate copies of the Original Work and
|
||||||
|
Derivative Works to the public, provided that prior to any such
|
||||||
|
distribution or communication You first place a machine-readable copy
|
||||||
|
of the Source Code of the Original Work and such Derivative Works that
|
||||||
|
You intend to distribute or communicate in an information repository
|
||||||
|
reasonably calculated to permit inexpensive and convenient access
|
||||||
|
thereto by the public (“Information Repository”) for as long as You
|
||||||
|
continue to distribute or communicate said copies, accompanied by an
|
||||||
|
irrevocable offer to license said copies to the public free of charge
|
||||||
|
under this License, said offer valid starting no later than 12 months
|
||||||
|
after You first distribute or communicate said copies;
|
||||||
|
|
||||||
|
d. to perform the Original Work publicly; and
|
||||||
|
|
||||||
|
e. to display the Original Work publicly.
|
||||||
|
|
||||||
|
2. **Grant of Patent License.** Licensor grants You a worldwide, royalty-free,
|
||||||
|
non-exclusive, sublicensable license, under patent claims owned or controlled
|
||||||
|
by the Licensor that are embodied in the Original Work as furnished by the
|
||||||
|
Licensor, for the duration of the patents, to make, use, sell, offer for sale,
|
||||||
|
have made, and import the Original Work and Derivative Works.
|
||||||
|
|
||||||
|
3. **Grant of Source Code License.** The "Source Code" for a work means the
|
||||||
|
preferred form of the work for making modifications to it and all available
|
||||||
|
documentation describing how to modify the work. Licensor agrees to provide a
|
||||||
|
machine-readable copy of the Source Code of the Original Work along with each
|
||||||
|
copy of the Original Work that Licensor distributes. Licensor reserves the
|
||||||
|
right to satisfy this obligation by placing a machine-readable copy of said
|
||||||
|
Source Code in an Information Repository for as long as Licensor continues to
|
||||||
|
distribute the Original Work.
|
||||||
|
|
||||||
|
4. **Exclusions From License Grant.** Neither the names of Licensor, nor the
|
||||||
|
names of any contributors to the Original Work, nor any of their trademarks or
|
||||||
|
service marks, may be used to endorse or promote products derived from this
|
||||||
|
Original Work without express prior permission of the Licensor. Except as
|
||||||
|
expressly stated herein, nothing in this License grants any license to
|
||||||
|
Licensor's trademarks, copyrights, patents, trade secrets or any other
|
||||||
|
intellectual property. No patent license is granted to make, use, sell, offer
|
||||||
|
for sale, have made, or import embodiments of any patent claims other than the
|
||||||
|
licensed claims defined in Section 2. No license is granted to the trademarks
|
||||||
|
of Licensor even if such marks are included in the Original Work. Nothing in
|
||||||
|
this License shall be interpreted to prohibit Licensor from licensing under
|
||||||
|
terms different from this License any Original Work that Licensor otherwise
|
||||||
|
would have a right to license.
|
||||||
|
|
||||||
|
5. **External Deployment.** The term "External Deployment" means the use,
|
||||||
|
distribution, or communication of the Original Work or Derivative Works in any
|
||||||
|
way such that the Original Work or Derivative Works may be used by anyone other
|
||||||
|
than You, whether those works are distributed or communicated to those persons
|
||||||
|
or made available as an application intended for use over a network. As an
|
||||||
|
express condition for the grants of license hereunder, You must treat any
|
||||||
|
External Deployment by You of the Original Work or a Derivative Work as a
|
||||||
|
distribution under section 1(c).
|
||||||
|
|
||||||
|
6. **Attribution Rights.** You must retain, in the Source Code of any
|
||||||
|
Derivative Works that You create, all copyright, patent, or trademark notices
|
||||||
|
from the Source Code of the Original Work, as well as any notices of licensing
|
||||||
|
and any descriptive text identified therein as an "Attribution Notice." You
|
||||||
|
must cause the Source Code for any Derivative Works that You create to carry a
|
||||||
|
prominent Attribution Notice reasonably calculated to inform recipients that
|
||||||
|
You have modified the Original Work.
|
||||||
|
|
||||||
|
7. **Warranty of Provenance and Disclaimer of Warranty.** Licensor warrants
|
||||||
|
that the copyright in and to the Original Work and the patent rights granted
|
||||||
|
herein by Licensor are owned by the Licensor or are sublicensed to You under
|
||||||
|
the terms of this License with the permission of the contributor(s) of those
|
||||||
|
copyrights and patent rights. Except as expressly stated in the immediately
|
||||||
|
preceding sentence, the Original Work is provided under this License on an "AS
|
||||||
|
IS" BASIS and WITHOUT WARRANTY, either express or implied, including, without
|
||||||
|
limitation, the warranties of non-infringement, merchantability or fitness for
|
||||||
|
a particular purpose. THE ENTIRE RISK AS TO THE QUALITY OF THE ORIGINAL WORK IS
|
||||||
|
WITH YOU. This DISCLAIMER OF WARRANTY constitutes an essential part of this
|
||||||
|
License. No license to the Original Work is granted by this License except
|
||||||
|
under this disclaimer.
|
||||||
|
|
||||||
|
8. **Limitation of Liability.** Under no circumstances and under no legal
|
||||||
|
theory, whether in tort (including negligence), contract, or otherwise, shall
|
||||||
|
the Licensor be liable to anyone for any indirect, special, incidental, or
|
||||||
|
consequential damages of any character arising as a result of this License or
|
||||||
|
the use of the Original Work including, without limitation, damages for loss of
|
||||||
|
goodwill, work stoppage, computer failure or malfunction, or any and all other
|
||||||
|
commercial damages or losses. This limitation of liability shall not apply to
|
||||||
|
the extent applicable law prohibits such limitation.
|
||||||
|
|
||||||
|
9. **Acceptance and Termination.** If, at any time, You expressly assented to
|
||||||
|
this License, that assent indicates your clear and irrevocable acceptance of
|
||||||
|
this License and all of its terms and conditions. If You distribute or
|
||||||
|
communicate copies of the Original Work or a Derivative Work, You must make a
|
||||||
|
reasonable effort under the circumstances to obtain the express assent of
|
||||||
|
recipients to the terms of this License. This License conditions your rights to
|
||||||
|
undertake the activities listed in Section 1, including your right to create
|
||||||
|
Derivative Works based upon the Original Work, and doing so without honoring
|
||||||
|
these terms and conditions is prohibited by copyright law and international
|
||||||
|
treaty. Nothing in this License is intended to affect copyright exceptions and
|
||||||
|
limitations (including 'fair use' or 'fair dealing'). This License shall
|
||||||
|
terminate immediately and You may no longer exercise any of the rights granted
|
||||||
|
to You by this License upon your failure to honor the conditions in Section
|
||||||
|
1(c).
|
||||||
|
|
||||||
|
10. **Termination for Patent Action.** This License shall terminate
|
||||||
|
automatically and You may no longer exercise any of the rights granted to You
|
||||||
|
by this License as of the date You commence an action, including a cross-claim
|
||||||
|
or counterclaim, against Licensor or any licensee alleging that the Original
|
||||||
|
Work infringes a patent. This termination provision shall not apply for an
|
||||||
|
action alleging patent infringement by combinations of the Original Work with
|
||||||
|
other software or hardware.
|
||||||
|
|
||||||
|
11. **Jurisdiction, Venue and Governing Law.** Any action or suit relating to
|
||||||
|
this License may be brought only in the courts of a jurisdiction wherein the
|
||||||
|
Licensor resides or in which Licensor conducts its primary business, and under
|
||||||
|
the laws of that jurisdiction excluding its conflict-of-law provisions. The
|
||||||
|
application of the United Nations Convention on Contracts for the International
|
||||||
|
Sale of Goods is expressly excluded. Any use of the Original Work outside the
|
||||||
|
scope of this License or after its termination shall be subject to the
|
||||||
|
requirements and penalties of copyright or patent law in the appropriate
|
||||||
|
jurisdiction. This section shall survive the termination of this License.
|
||||||
|
|
||||||
|
12. **Attorneys' Fees.** In any action to enforce the terms of this License or
|
||||||
|
seeking damages relating thereto, the prevailing party shall be entitled to
|
||||||
|
recover its costs and expenses, including, without limitation, reasonable
|
||||||
|
attorneys' fees and costs incurred in connection with such action, including
|
||||||
|
any appeal of such action. This section shall survive the termination of this
|
||||||
|
License.
|
||||||
|
|
||||||
|
13. **Miscellaneous.** If any provision of this License is held to be
|
||||||
|
unenforceable, such provision shall be reformed only to the extent necessary to
|
||||||
|
make it enforceable.
|
||||||
|
|
||||||
|
14. **Definition of "You" in This License.** "You" throughout this License,
|
||||||
|
whether in upper or lower case, means an individual or a legal entity
|
||||||
|
exercising rights under, and complying with all of the terms of, this License.
|
||||||
|
For legal entities, "You" includes any entity that controls, is controlled by,
|
||||||
|
or is under common control with you. For purposes of this definition, "control"
|
||||||
|
means (i) the power, direct or indirect, to cause the direction or management
|
||||||
|
of such entity, whether by contract or otherwise, or (ii) ownership of fifty
|
||||||
|
percent (50%) or more of the outstanding shares, or (iii) beneficial ownership
|
||||||
|
of such entity.
|
||||||
|
|
||||||
|
15. **Right to Use.** You may use the Original Work in all ways not otherwise
|
||||||
|
restricted or conditioned by this License or by law, and Licensor promises not
|
||||||
|
to interfere with or be responsible for such uses by You.
|
||||||
|
|
||||||
|
16. **Modification of This License.** This License is Copyright © 2007 Zooko
|
||||||
|
Wilcox-O'Hearn. Permission is granted to copy, distribute, or communicate this
|
||||||
|
License without modification. Nothing in this License permits You to modify
|
||||||
|
this License as applied to the Original Work or to Derivative Works. However,
|
||||||
|
You may modify the text of this License and copy, distribute or communicate
|
||||||
|
your modified version (the "Modified License") and apply it to other original
|
||||||
|
works of authorship subject to the following conditions: (i) You may not
|
||||||
|
indicate in any way that your Modified License is the "Bootstrap Open Source
|
||||||
|
Licence" or "BOSL" and you may not use those names in the name of your Modified
|
||||||
|
License; and (ii) You must replace the notice specified in the first paragraph
|
||||||
|
above with the notice "Licensed under <insert your license name here>" or with
|
||||||
|
a notice of your own that is not confusingly similar to the notice in this
|
||||||
|
License.
|
||||||
|
|
21
app/Main.hs
21
app/Main.hs
|
@ -93,8 +93,17 @@ sendZec user pwd =
|
||||||
liftIO . putStrLn $ " Sending from " ++ show (addList !! (idx - 1))
|
liftIO . putStrLn $ " Sending from " ++ show (addList !! (idx - 1))
|
||||||
t <- liftIO . prompt $ " > Enter destination address: "
|
t <- liftIO . prompt $ " > Enter destination address: "
|
||||||
let addChk = validateAddress (T.pack t)
|
let addChk = validateAddress (T.pack t)
|
||||||
if addChk
|
case addChk of
|
||||||
then do
|
Nothing -> liftIO . putStrLn $ " Invalid address, cancelling."
|
||||||
|
Just Transparent -> do
|
||||||
|
liftIO . putStrLn $ " Address is valid!"
|
||||||
|
a <- liftIO . prompt $ " > Enter ZEC amount: "
|
||||||
|
case (readMaybe a :: Maybe Double) of
|
||||||
|
Just amt -> do
|
||||||
|
liftIO $
|
||||||
|
sendTx user pwd (addList !! (idx - 1)) (T.pack t) amt Nothing
|
||||||
|
Nothing -> liftIO . putStrLn $ " Invalid amount"
|
||||||
|
Just _ -> do
|
||||||
liftIO . putStrLn $ " Address is valid!"
|
liftIO . putStrLn $ " Address is valid!"
|
||||||
a <- liftIO . prompt $ " > Enter ZEC amount: "
|
a <- liftIO . prompt $ " > Enter ZEC amount: "
|
||||||
case (readMaybe a :: Maybe Double) of
|
case (readMaybe a :: Maybe Double) of
|
||||||
|
@ -113,11 +122,11 @@ sendZec user pwd =
|
||||||
(T.pack t)
|
(T.pack t)
|
||||||
amt
|
amt
|
||||||
(if repTo
|
(if repTo
|
||||||
then T.pack m <>
|
then Just
|
||||||
"\nReply-To:\n" <> addy (addList !! (idx - 1))
|
(T.pack m <>
|
||||||
else T.pack m)
|
"\nReply-To:\n" <> addy (addList !! (idx - 1)))
|
||||||
|
else Just $ T.pack m)
|
||||||
Nothing -> liftIO . putStrLn $ " Invalid amount"
|
Nothing -> liftIO . putStrLn $ " Invalid amount"
|
||||||
else liftIO . putStrLn $ " Invalid address, cancelling."
|
|
||||||
return NoAction
|
return NoAction
|
||||||
|
|
||||||
createUA :: B.ByteString -> B.ByteString -> Commands ()
|
createUA :: B.ByteString -> B.ByteString -> Commands ()
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
name: zenith
|
name: zenith
|
||||||
version: 0.3.1.0
|
version: 0.3.1.0
|
||||||
github: "pitmutt/zenit"
|
git: "https://gitlab.com/pitmutt/zenith"
|
||||||
license: MIT
|
license: BOSL
|
||||||
author: "Rene Vergara"
|
author: "Rene Vergara"
|
||||||
maintainer: "rene@vergara.network"
|
maintainer: "rene@vergara.network"
|
||||||
copyright: "Copyright (c) 2022 Vergara Technologies LLC"
|
copyright: "Copyright (c) 2022 Vergara Technologies LLC"
|
||||||
|
@ -9,15 +9,16 @@ copyright: "Copyright (c) 2022 Vergara Technologies LLC"
|
||||||
extra-source-files:
|
extra-source-files:
|
||||||
- README.md
|
- README.md
|
||||||
- CHANGELOG.md
|
- CHANGELOG.md
|
||||||
|
- zenith.cfg
|
||||||
|
|
||||||
# Metadata used when publishing your package
|
# Metadata used when publishing your package
|
||||||
# synopsis: Short description of your package
|
synopsis: Haskell CLI for Zcash Full Node
|
||||||
# category: Web
|
# category: Web
|
||||||
|
|
||||||
# To avoid duplicated efforts in documentation and dealing with the
|
# To avoid duplicated efforts in documentation and dealing with the
|
||||||
# complications of embedding Haddock markup inside cabal files, it is
|
# complications of embedding Haddock markup inside cabal files, it is
|
||||||
# common to point users to the README.md file.
|
# common to point users to the README.md file.
|
||||||
description: Please see the README on GitLab at <https://gitlab.com/pitmutt/zenit#readme>
|
description: Please see the README on GitLab at <https://gitlab.com/pitmutt/zenith#readme>
|
||||||
|
|
||||||
dependencies:
|
dependencies:
|
||||||
- base >= 4.7 && < 5
|
- base >= 4.7 && < 5
|
||||||
|
|
|
@ -320,8 +320,12 @@ getAddresses :: AddressGroup -> [ZcashAddress]
|
||||||
getAddresses ag = agtransparent ag <> agsapling ag <> agunified ag
|
getAddresses ag = agtransparent ag <> agsapling ag <> agunified ag
|
||||||
|
|
||||||
-- | Helper function to validate potential Zcash addresses
|
-- | Helper function to validate potential Zcash addresses
|
||||||
validateAddress :: T.Text -> Bool
|
validateAddress :: T.Text -> Maybe ZcashPool
|
||||||
validateAddress txt = (tReg || sReg && isJust chk) || (uReg && isJust chk)
|
validateAddress txt --(tReg || sReg && isJust chk) || (uReg && isJust chk)
|
||||||
|
| tReg = Just Transparent
|
||||||
|
| sReg && isJust chk = Just Sapling
|
||||||
|
| uReg && isJust chk = Just Orchard
|
||||||
|
| otherwise = Nothing
|
||||||
where
|
where
|
||||||
transparentRegex = "^t1[a-zA-Z0-9]{33}$" :: String
|
transparentRegex = "^t1[a-zA-Z0-9]{33}$" :: String
|
||||||
shieldedRegex = "^zs[a-zA-Z0-9]{76}$" :: String
|
shieldedRegex = "^zs[a-zA-Z0-9]{76}$" :: String
|
||||||
|
@ -397,33 +401,45 @@ sendTx ::
|
||||||
-> ZcashAddress
|
-> ZcashAddress
|
||||||
-> T.Text
|
-> T.Text
|
||||||
-> Double
|
-> Double
|
||||||
-> T.Text
|
-> Maybe T.Text
|
||||||
-> IO ()
|
-> IO ()
|
||||||
sendTx user pwd fromAddy toAddy amount memo = do
|
sendTx user pwd fromAddy toAddy amount memo = do
|
||||||
bal <- getBalance user pwd fromAddy
|
bal <- getBalance user pwd fromAddy
|
||||||
|
let valAdd = validateAddress toAddy
|
||||||
if sum bal - floor (amount * 100000000) >= 1000
|
if sum bal - floor (amount * 100000000) >= 1000
|
||||||
then do
|
then do
|
||||||
if source fromAddy /= ImportedWatchOnly
|
if source fromAddy /= ImportedWatchOnly
|
||||||
then do
|
then do
|
||||||
let privacyPolicy =
|
let privacyPolicy
|
||||||
if isNothing (account fromAddy) &&
|
| valAdd == Just Transparent = "AllowRevealedRecipients"
|
||||||
elem Transparent (pool fromAddy)
|
| isNothing (account fromAddy) &&
|
||||||
then "AllowRevealedSenders"
|
elem Transparent (pool fromAddy) = "AllowRevealedSenders"
|
||||||
else "AllowRevealedAmounts"
|
| otherwise = "AllowRevealedAmounts"
|
||||||
let pd =
|
let pd =
|
||||||
[ Data.Aeson.String (addy fromAddy)
|
case memo of
|
||||||
, Data.Aeson.Array
|
Nothing ->
|
||||||
(V.fromList
|
[ Data.Aeson.String (addy fromAddy)
|
||||||
[ object
|
, Data.Aeson.Array
|
||||||
[ "address" .= toAddy
|
(V.fromList
|
||||||
, "amount" .= amount
|
[object ["address" .= toAddy, "amount" .= amount]])
|
||||||
, "memo" .= encodeHexText' memo
|
, Data.Aeson.Number $ Scientific.scientific 1 1
|
||||||
]
|
, Data.Aeson.Number $ Scientific.scientific 1 (-5)
|
||||||
])
|
, Data.Aeson.String privacyPolicy
|
||||||
, Data.Aeson.Number $ Scientific.scientific 1 1
|
]
|
||||||
, Data.Aeson.Number $ Scientific.scientific 1 (-5)
|
Just memo' ->
|
||||||
, Data.Aeson.String privacyPolicy
|
[ Data.Aeson.String (addy fromAddy)
|
||||||
]
|
, Data.Aeson.Array
|
||||||
|
(V.fromList
|
||||||
|
[ object
|
||||||
|
[ "address" .= toAddy
|
||||||
|
, "amount" .= amount
|
||||||
|
, "memo" .= encodeHexText' memo'
|
||||||
|
]
|
||||||
|
])
|
||||||
|
, Data.Aeson.Number $ Scientific.scientific 1 1
|
||||||
|
, Data.Aeson.Number $ Scientific.scientific 1 (-5)
|
||||||
|
, Data.Aeson.String privacyPolicy
|
||||||
|
]
|
||||||
response <- makeZcashCall user pwd "z_sendmany" pd
|
response <- makeZcashCall user pwd "z_sendmany" pd
|
||||||
let rpcResp = decode response :: Maybe (RpcResponse T.Text)
|
let rpcResp = decode response :: Maybe (RpcResponse T.Text)
|
||||||
case rpcResp of
|
case rpcResp of
|
||||||
|
@ -582,8 +598,17 @@ sendWithUri user pwd fromAddy uri repTo = do
|
||||||
let parsedAddress = fst $ head reg A.! 1
|
let parsedAddress = fst $ head reg A.! 1
|
||||||
let parsedAmount = fst $ head reg A.! 2
|
let parsedAmount = fst $ head reg A.! 2
|
||||||
let parsedEncodedMemo = fst $ head reg A.! 3
|
let parsedEncodedMemo = fst $ head reg A.! 3
|
||||||
if validateAddress $ T.pack parsedAddress
|
let addType = validateAddress $ T.pack parsedAddress
|
||||||
then do
|
case addType of
|
||||||
|
Nothing -> putStrLn " Invalid address"
|
||||||
|
Just Transparent -> do
|
||||||
|
putStrLn $ " Address is valid: " ++ parsedAddress
|
||||||
|
case (readMaybe parsedAmount :: Maybe Double) of
|
||||||
|
Nothing -> putStrLn " Invalid amount."
|
||||||
|
Just amt -> do
|
||||||
|
putStrLn $ " Valid ZEC amount: " ++ show amt
|
||||||
|
sendTx user pwd fromAddy (T.pack parsedAddress) amt Nothing
|
||||||
|
Just _ -> do
|
||||||
putStrLn $ " Address is valid: " ++ parsedAddress
|
putStrLn $ " Address is valid: " ++ parsedAddress
|
||||||
case (readMaybe parsedAmount :: Maybe Double) of
|
case (readMaybe parsedAmount :: Maybe Double) of
|
||||||
Nothing -> putStrLn " Invalid amount."
|
Nothing -> putStrLn " Invalid amount."
|
||||||
|
@ -600,7 +625,7 @@ sendWithUri user pwd fromAddy uri repTo = do
|
||||||
(T.pack parsedAddress)
|
(T.pack parsedAddress)
|
||||||
amt
|
amt
|
||||||
(if repTo
|
(if repTo
|
||||||
then T.concat [decodedMemo, "\nReply-To:\n", addy fromAddy]
|
then Just $
|
||||||
else decodedMemo)
|
T.concat [decodedMemo, "\nReply-To:\n", addy fromAddy]
|
||||||
else putStrLn " Invalid address"
|
else Just decodedMemo)
|
||||||
else putStrLn "URI is not compliant with ZIP-321"
|
else putStrLn "URI is not compliant with ZIP-321"
|
||||||
|
|
|
@ -5,7 +5,7 @@ cabal-version: 1.12
|
||||||
-- see: https://github.com/sol/hpack
|
-- see: https://github.com/sol/hpack
|
||||||
|
|
||||||
name: zenith
|
name: zenith
|
||||||
version: 0.3.0.0
|
version: 0.3.1.0
|
||||||
description: Please see the README on GitLab at <https://gitlab.com/pitmutt/zenit#readme>
|
description: Please see the README on GitLab at <https://gitlab.com/pitmutt/zenit#readme>
|
||||||
homepage: https://github.com/pitmutt/zenit#readme
|
homepage: https://github.com/pitmutt/zenit#readme
|
||||||
bug-reports: https://github.com/pitmutt/zenit/issues
|
bug-reports: https://github.com/pitmutt/zenit/issues
|
||||||
|
|
Loading…
Reference in a new issue