Settings

Theme

How to Send a Swift Wire for Developers

iso20022js.com

66 points by svapnil a year ago · 31 comments

Reader

chuzz a year ago

Cool to see how swift wire payments works in practice, but using JS floating point numbers for money amounts is a disaster waiting to happen

  • RedShift1 a year ago

    That seems super dumb indeed. I really wish JSON had an actual decimal type, we already have valid "e" notation (like 10e2), why not have a "d" notation, like 5d3 (meaning 5.3) or 5.3d.

  • krystofee a year ago

    It would be if it did any arithmetic. But maybe it works without any computation. Then the fp arithmetic is not a problem. Or could you provide an example?

    • nine_k a year ago

      Neither 0.1 nor 0.01 are representable exactly in binary (much like 1/3 is not representable exactly in decimal). Thus means that your cents, if any, are never precise. Not a big deal for Swift transfers where you can safely round to cents. But various commissions, taxes, and fees are often very small fractions, and rounding errors become noticeable with large quantities of small amounts added / subtracted. They may be too small to matter financially, but they are bothersome because your sums do not match exactly where they should, and this affects trust to the system.

      IDK about banks; in one billing system where I was involved we used decimals (and clear rules of assignment of the rounding errors), in another, all amounts were in picodollars.

      • krystofee a year ago

        Yeah, they are not, but still, afaik when I have 0.1 or 0.01 in some variable and pass it around the system it doesn't suddenly change to 0.10000000000012 (or whatever), but the problem arises in case you want to make arithmetic with it, like 0.1 + 0.2 !== 0.3, which you do not do in this library, you just pass "calculated" value how much to send where and you are done.

        Partially Im just playing the devils advocate here, I know that you have to use Decimals for working with prices etc., (maybe they did not use it because it will be pretty fat dependency), but still imho it's not needed.

  • morepork a year ago

    Should be fine up to about 9 quadrillion[1]. Though with arithmetic it can get messy. The example doesn't show, but I hope dollar amounts are in cents and don't use decimals.

    Maybe when sending money to Zimbabwe it could be an issue.

    [1] https://developer.mozilla.org/en-US/docs/Web/JavaScript/Refe...

  • svapnilOP a year ago

    Thanks for bringing this up chuzz - we're actually only using base amounts for the money representation for amounts here. (no $2.3232321), only (amount: 232)

    See the https://dinerojs.com/ package to see how money is handled (tldr it's a combination of currency and amount which helps us get to the root #)

svapnilOP a year ago

Hey HackerNews,

I published iso20022js.com a few weeks ago, and I was incredibly surprised by the overwhelming traction it received. I wanted to share more about some payments fundamentals that engineers might need in order to run this package - specifically, how sending these types of bank payments actually works.

  • miki123211 a year ago

    > I published iso20022js.com a few weeks ago

    And from the linked article:

    > iso20022.js is the most popular open-source library that you can use to create ISO20022 messages programatically

    How's that possible?

    • svapnilOP a year ago

      It's the largest one with traction so far! It currently has over 300 stars on Github, meaning it's the largest package that I believe people care about right now

    • sedatk a year ago

      If it’s the only library…

acheong08 a year ago

> you will need to configure the bank to allow for direct transmission. This is a process that your bank will need to complete with you.

How easy is this process? Are all banks required to provide such a service? How about countries outside the USA

  • paperpunk a year ago

    This is frankly the actually difficult part of the process. ISO20022 is just a way to send messages, your actual commercial and settlement arrangements still need to be done. Banks are not required to provide such a service, you will specifically need an arrangement with a bank that offers that. Or more likely with an intermediary like Wise which will abstract the distractions like ISO20022 away from you.

    • arianvanp a year ago

      In the EU the PSD2 directive explains which market parties can apply for access to these systems. Which usually means you need to have a company that has interest in this kind of access and provide service to third parties. Unfortunately i think PSD2 only sets technical rules for authentication. Not for the actual API. So the bank might not give you direct access to SWIFT but to an API that abstracts it instead.

    • kreetx a year ago

      AFAIK, Wise has currently stopped allowing payments through its API[1] for private persons due to regulation, and there don't seem to be any other worldwide providers to do so.

      [1] You can send prepared payment orders to Wise, but still need to log in and manually approve them.

  • svapnilOP a year ago

    It is non-trivial. Every corporate bank usually provides some type of treasury services, which is how companies programmatically move money.

    As far as I know, this is an international phenomenon. Keep in mind this is corporate banking, not consumer banking.

    I'd happy answer any other questions you have @ https://cal.com/woodside/iso20022js

  • CRConrad a year ago

    > Are all banks required to provide such a service? How about countries outside the USA

    I'd be more worried about banks in the USA than outside. You won't get "No, we only take endorsed and double-signed paper checks!" from a European bank...

hansoolo a year ago

But sending the transaction is just ONE part of the ISO. There are a lot of other different messages that are part of the standard: https://www.iso20022.org/iso-20022-message-definitions

  • svapnilOP a year ago

    Great point hansoolo,

    ISO20022 has a huge namespace and can do all kinds of things. My current focus on making transaction banking namespaces more accessible (think pain.001 002 and 008) aswell as CAMT files

    • hansoolo a year ago

      Great effort, thanks! I just recently had to implement camt054 for our client and others will follow, because it's becoming the new standard soon. There's definitely a whole lot more in that namespace, yes.

      I accidently also stumbled across the different einvoicing types that exist. What a space to explore :)

cyberpunk a year ago

This is cool; I'd love to hear more about how the actual transfer of money works e.g clearing, r-transactions and so on if you're looking for a follow up blog ;)

kirmerzlikin a year ago

Nice article! It's always interesting to look behind the scenes of payment infrastructure.

BTW, when I tried the interactive demo [1] I noticed that it appended "undefined" to the end of the generated XML. Happens both in Firefox and Chrome, so it doesn't seem to be a browser quirk.

[1] https://www.iso20022js.com/demo

paperpunk a year ago

nit: it’s been called ‘Swift’ for a while, not ‘SWIFT’.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection