From c006b721581d39a5edf1360d1655225521bcb977 Mon Sep 17 00:00:00 2001
From: Charlie Wilkin <charlie@busyboredom.com>
Date: Sat, 11 Mar 2023 17:38:37 +0000
Subject: [PATCH] Standalone AcceptXMR

---
 busyboredom-standalone-acceptxmr.md | 103 ++++++++++++++++++++++++++++
 1 file changed, 103 insertions(+)
 create mode 100644 busyboredom-standalone-acceptxmr.md

diff --git a/busyboredom-standalone-acceptxmr.md b/busyboredom-standalone-acceptxmr.md
new file mode 100644
index 00000000..9d852b88
--- /dev/null
+++ b/busyboredom-standalone-acceptxmr.md
@@ -0,0 +1,103 @@
+---
+layout: fr
+title: Standalone AcceptXMR
+author: busyboredom
+date: February 31, 2023
+amount: 14
+milestones:
+  - name: Maintenance
+    funds: 14
+    done:
+    status: unfinished
+payouts:
+  - date:
+    amount:
+---
+
+# Standalone AcceptXMR
+Another payment gateway CCS proposal.
+
+## Summary
+I would like to create a standalone, dockerized, AcceptXMR-based payment gateway with wordpress
+support.
+
+AcceptXMR ([demo](https://busyboredom.com/projects/acceptxmr),
+[docs](https://docs.rs/acceptxmr/latest/acceptxmr/),
+[repo](https://github.com/busyboredom/acceptxmr/)) is a payment gateway library (or crate, in rust
+lingo) I wrote as a hobby project and have made available to the community. While my library serves
+its purpose well, I understand that most merchants are not programmers therefor cannot use
+AcceptXMR.
+
+This proposal aims to make AcceptXMR usable for anyone capable running a docker container and
+installing a wordpress plugin.
+
+## Why AcceptXMR
+Lots of reasons!
+* View pair only, no hot wallet.
+* Subaddress based (as opposed to the older integrated addresses).
+* Pending invoices can be stored persistently, enabling recovery from power loss.
+* Ignores transactions with non-zero timelocks.
+* Zero-conf works out of the box.
+* No local node, wallet RPC, or block explorer needed. Just pick a public remote node.
+
+And of course, I am already intimately familiar with it.
+
+## How It'll Happen
+I will dedicate a portion of my weekends (you can expect about 10 hours a week on average) to
+completing the following milestones. There will be some weeks with more progress and others with
+less, but that's the average I'll be aiming for.
+
+### Dockerize AcceptXMR
+_14 XMR from xmrSale's abandoned funding._
+
+This is the largest milestone. I'll be taking the webserver and frontend work you see in my demo,
+cleaning it up significantly to bring it up to production standards and dockerizing it for easy
+setup. I will also provide documentation on how to perform that setup.
+
+### Wordpress Plugin
+_10 XMR from xmrSale's abandoned funding._
+
+Wordpress is popular, and it has a plugin system that supports custom payment gateways. I will write
+a wordpress plugin for the freshly dockerized AcceptXMR implementation. I will also provide
+documentation on how to use the plugin.
+
+### Maintenance for 1 Year
+_20 XMR total, with 6 XMR coming from xmrSale's abandoned funding and the remaining 14 XMR coming
+from this CCS proposal._
+
+Both rust and monero have rapidly changing ecosystems. Left alone, my work would likely be out of
+date by the end of the year due to breaking changes in my library's dependencies if nothing else.
+Keeping AcceptXMR up-to-date and functional is something I currently do for free, but building out a
+full standalone gateway adds overhead. For this reason, I've bookmarked 20 XMR for maintenance for 1
+year from the funding date.
+
+I am hesitant to provide target dates for first  two milestones above, but I have been maintaining
+AcceptXMR for over a year now and I don't plan on ghosting on it now.
+
+## Stretch Goals / Future work
+I'm not promising any of the following happens, but I'm putting it here to let the community know
+it's on my radar and I want to do it if I get the opportunity:
+* TOR support for the daemon RPC connection.
+* A no-JS frontend. I have an example with this implemented on github, but I'll have to clean it up
+a bit and integrate it into the new dockerized setup.
+* ZMQ support as a more performant alternative to polling the remote node.
+
+## Prerequisites
+Before I start work on this CCS, I'll need to wrap up changes I'm making with v0.12.0 of AcceptXMR.
+I'm not charging for that work, I'm just disclosing here that I need to resolve the issues in that
+milestone before I start work on this CCS.
+
+## License
+AcceptXMR is dual-licensed under the MIT and Apache 2.0 licenses. I am not planning on changing the
+license. It will always be under a permissive license.
+
+## About Me
+Busyboredom is _not_ an anonymous alias, you can see my minimally-redacted resume on my personal
+website [busyboredom.com](https://busyboredom.com).
+
+Proposal Expiration: January 1st, 2025.
+
+Note: This CCS was originally intended to be funded entirely by the 30 XMR leftover from the abanoned
+xmrSale project. At the request of the community, I have extended my maintenance commitment and
+increased the maintenance budget by 14 XMR. This change allows CCS donors to act as a final check on
+whether this proposal goes forward.
-- 
GitLab