Apply for NGI Taler grant for Taler-OFN integration

The NLnet foundation is calling for NGI Taler projects with a deadline of April 1st 2025 12:00 CEST (noon). Project proposal between 5k and 50k EUR are in scope.

Integrating GNU Taler with the Open Food Network aligns with our mission and values extremely well. But there is no open Ruby implementation yet. We can create a public library and integrate it in OFN for production use while strengthening the whole eco-system. So let’s flesh out the funding application. Below are the application questions. I added warning signs to all unanswered questions. We can remove them as we complete those.

Contact information

CoopCircuits

@Rachel will submit the application.

General project information

Proposal name

Taler payment for Ruby e-commerce including Open Food Network

Website / wiki

https://openfoodnetwork.org/

Abstract: Can you explain the whole project and its expected outcome(s).

(You have 1200 characters) :warning:

Please be short and to the point in your answers; focus primarily on the what and how, not so much on the why. Add longer descriptions as attachments (see below). If English isn’t your first language, don’t worry — our reviewers don’t care about spelling errors, only about great ideas. We apologise for the inconvenience of having to submit in English. On the up side, you can be as technical as you need to be (but you don’t have to). Do stay concrete. Use plain text in your reply only, if you need any HTML to make your point please include this as attachment.

Develop an open-source Ruby library (gem) for Taler payment integration and add Taler payment method to the Open Food Network e-commerce platform.

The Open Food Network platform is used by community organisations and small enterprises to sell food and other local produce. Currently, customers can pay for their orders online with PayPal or Stripe. But we would like to add a new option to pay with GNU Taler. The API interaction with the Taler backend will be shared in a re-usable library for other e-commerce platforms written in Ruby.

Have you been involved with projects or organisations relevant to this project before? And if so, can you tell us a bit about your contributions?

(Optional) This can help us determine if you are the right person to undertake this effort. (max 2500 characters) :warning:

Part of our team are also members of the Open Food Network (OFN) development team. OFN has been working in the Ruby on Rails community for over ten years. All our products are open-source.

We contribute back to related projects. This included integrating PayPal and Stripe into the Open Food Network e-commerce app. We contributed to ActiveMerchant:

We also created new Ruby gems for the community:

And we’ve been successful in our NGI Sargasso grant for the Cooperative Agri-Data Portal.

Requested support

Requested Amount (in Euro)

47,520

Explain what the requested budget will be used for? :warning:

Does the project have other funding sources, both past and present?
(If you want, you can in addition attach a budget at the bottom of the form)
Explain costs for hardware, human labor (including rates used), travel cost to technical meetings, etc. (max 2500 characters, be concise)

CoopCircuits and other members of the OFN network around the world are recipients of licence fees for the use of the e-commerce platform. Each year, we dedicate a chunk of these fees to the development of new feature and overall maintenance.

Adding Taler payments to the OFN platform can be divided into two parts: a shared library and integrating the library into OFN. Development work is estimated as time to write the code. We then add overheads for project management, review, testing and maintenance.
Given we want to use this in production, we added cost related to managing feedback from user group.

Create a taler-payment library (gem):

  • Study existing implementations (PHP, Python): 2 days
  • Set up gem with automated test environment for Taler: 1 day
  • Implement payments in Ruby including tests: 5 days
    • GNU Taler backend URL
    • GNU Taler backend API key
    • App endpoint for fulfillment URL (order_id / token)

Use the Taler payment gateway in OFN:

  • Shape and design UX and scope of implementation: 1 day
  • Add enterprise page to add Taler as payment method: 3 days
  • Add customer UX for Taler payments: 3 days
  • Integrate Taler payment logic into existing payment system: 2 days
  • Integrate Taler refunds into existing payment system: 2 days

Getting the gateway ready for production:

  • Create a group of users happy to beta-test the platform with their close customers: 1 day
  • Organise testing phases during development: 3 days
  • Once the gateway is ready for production, launch with the same group of tester at first and increase the number of users until the gateway is available for everyone: 2 days

Documentation & Dissemination

  • Ensure the ruby gem is fully documented: 1 day
  • Communicate on the gem in related blog, forum and networks of the Ruby community: 2 days
  • Present the project in relevant conferences in Europe: 2 days

Total: 30 days
Effective daily rate including all overheads (project management, meetings, testing): 1,584 EUR
Total budget needed: 47,520 EUR

Compare your own project with existing or historical efforts.

E.g. what is new, more thorough or otherwise different. (max 4000 characters, be concise) :warning:

Taler payments are available in Joomla, Magento and WooCommerce. There’s no (public/open) implementation in Ruby.

We want to add Taler payments to the Open Food Network platform. We process over 16,000 orders per month globally and our users need a cheaper way to process payments that is reliable and aligns with our values.

We will also publish a Ruby library on rubygems.org to enable other e-commerce software to adapt Taler more easily. The Open Food Network was originally built with the Spree e-commerce framework which is used by many online shops. Our implementation should be easily adaptable by Spree and its fork Solidus.

Sharing the Taler payment library will also enable us to share the maintenance work with our active community of developers. We have over 200 volunteer contributors to our main project. And once other projects start using the same library, we’ll have a joint interest in the maintenance.

What are significant technical challenges you expect to solve during the project, if any?

(optional but recommended, max 5000 characters) :warning:

The most obvious challenge is that GNU Taler isn’t used in production yet. The API may change and we may have to update our code later to take Taler payments to production. We won’t be able to complete delivery until we have a real bank to participate.

The other challenge is that our code base is over ten years old and relatively big. The code around payment methods hasn’t had any significant changes in 4 years. So we planned this work with a margin to address technical debt and unknown hurdles in this part.

Otherwise, the API integration to perform Taler payments seems simple. The customer doesn’t have to enter any payment details on our site and we don’t need to embed any additional Javascript. The payment is handled by the existing app or browser extension with the existing backend.

Describe the ecosystem of the project, and how you will engage with relevant actors and promote the outcomes?

E.g. which actors will you involve? Who should run or deploy your solution to make it a success? (max 2500 characters, be concise) :warning:

CoopCircuits is part of the global Open Food Network, which is a group of not-for-profit organisations. We have a team of paid full-stack engineers working on the Open Food Network platform. We also attract many volunteer contributions from the open-source community. We benefit from the contributions and provide code reviews and learning experiences in exchange. Our visibility in the Ruby on Rails community will help to promote the new Taler payments gem (library).

On the other side, we have customer support, consulting and research teams in several countries to promote a new payment option to all kind of small to medium food enterprises. Local food hubs and co-ops often rely on volunteer work and don’t have the money to pay for high transaction fees. The next best alternative is to reconcile bank transfers which is very labour-intensive.

2 Likes

Great job ! Thank you.
Does your offer include splitting of payments between various producers of a hub? If this is the case I think it is worth mentioning it as it would be a great achievement.

No, splitting payments is not supported.

Maybe one day Taler will support batch payments in which case the user can then confirm all the different amounts they are paying to different people in one transaction. Otherwise we would need in intermediate account. The customer pays into that proxy account and then we split the money to go to the suppliers. This is not a problem Taler is solving at the moment.

1 Like

Hi folks

Me and ChatGPT took a shot at a revised version - I think it’s pretty much good to go at this point - see what you think:

@maikel @Rachel @nicotentin

I suggest @maikel and/or @Rachel take a quick look at this to confirm all the techical details have been carried over correctly

I’ll note I think this felt like a very efficient proposal writing and suggest we try to replicate something similar for future NGI applications

2 Likes

Since it’s about a technical implementation, I felt quite confident coming up with a scope and estimate. Thank you all for making it ready for submission. I would have struggled with that.

1 Like

@maikel I just want to make sure you are in line with point 4. of the technical challenges that was not present in your version:

  1. Banking Support:
    We cannot take Taler fully into production without a cooperating financial institution. The integration will be developed and tested in sandbox mode and validated by our user community until bank support is available.

What does this mean? We will need to do a partnership with a bank?

We don’t have to partner with a bank ourselves. But the Taler eco-system as a whole needs the support of a bank to transfer money into your online-wallet. And at this point of time, there is no bank supporting it yet. The whole Taler system is only working with test-servers. Nobody is working with real money yet. Until that changes, we can’t offer any value to our customers. Taler can’t be used yet.

But there is support from the EU now and funding for implementations. So hopefully there will be broad support soon. We would implement Taler to help with the chicken-and-egg problem.

And if the big banks don’t want to support it, someone could still start a virtual currency for local trade. Then it just becomes a bit grey around financial regulations.

2 Likes

Application sent with CoopCircuits bonjour email :muscle:

A proposal for a grant application was sent to NLnet Foundation (https://nlnet.nl) using this email address. Your project has received code 2025-04-163. If you want to make changes to this proposal before the deadline, feel free to resubmit. We will send you a follow-up email after the deadline has passed to provide more information regarding the review process.

Thanks everyone! I agree with David, we seemed pretty efficient on this one. Congrats!

2 Likes

Thanks Rachel ! I was just wondering if the application was sent and connecting to check …