diff --git a/LICENSE.md b/LICENSE.md index b837db0..f3098fa 100644 --- a/LICENSE.md +++ b/LICENSE.md @@ -1,202 +1,339 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the 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. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright 2019-2020 Vincenzo Palazzo vincenzo.palazzo@protonmail.com - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. \ No newline at end of file + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Lesser General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + This is a wrapper for c-lightning RPC interface. + Copyright (C) 2020 Vincenzo Palazzo vincenzopalazzodev@gmail.com + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + , 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. \ No newline at end of file diff --git a/README.md b/README.md index 5b7df99..f6de5af 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ final-Icon

-This is a simple wrapper for c-lightning rpc, this project is inspired by this +This is a wrapper for c-lightning rpc, this project is inspired by this [pull request](https://github.com/ElementsProject/lightning/pull/2223) by @renepickhardt. The wrapper aims to be versatile, the final version should allow the user to execute commands even of custom plugins, allowing them to write the code for the command. @@ -82,6 +82,21 @@ The library support now the plugins and you can subscribe the plugin to notify w ### Example +### Plugin example + +```java + @RPCMethod( + name = "annotation_hello", + description = "Annotation plugin" + ) + public void hello(CLightningPlugin plugin, CLightningJsonObject request, CLightningJsonObject response) { + log(CLightningLevelLog.WARNING, request.toString()); + response.add("type", "random"); + } +``` + +### Notification example + ```java @Subscription(notification = "invoice_creation") public void doInvoiceCreation(CLightningJsonObject data){ @@ -90,5 +105,42 @@ The library support now the plugins and you can subscribe the plugin to notify w } ``` +### Hook example + +```java + @Hook(hook = "rpc_command") + public void logAllRPCCommand(CLightningPlugin plugin, CLightningJsonObject request, CLightningJsonObject response) { + log(CLightningLevelLog.WARNING, request.toString()); + response.add("result", "continue"); + } +``` + ## Support -For any additional support you can use this bitcoin address: `3BQ8qbn8hLdmBKEjt1Hj1Z6SiDsnjJurfU` +For any additional support you can use this bitcoin address: `` +If you like the library and want support it, please considerer to donate with the following system +- [liberapay.com/vincenzopalazzo](https://liberapay.com/vincenzopalazzo) +- [3BQ8qbn8hLdmBKEjt1Hj1Z6SiDsnjJurfU](bitcoin:3BQ8qbn8hLdmBKEjt1Hj1Z6SiDsnjJurfU) +- [Github support](https://github.com/sponsors/vincenzopalazzo) + +## License + +
+ +
+ + This is a wrapper for c-lightning RPC interface. + Copyright (C) 2020 Vincenzo Palazzo vincenzopalazzodev@gmail.com + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + *51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ \ No newline at end of file diff --git a/docs/index-all.html b/docs/index-all.html index b2d3598..e813bee 100644 --- a/docs/index-all.html +++ b/docs/index-all.html @@ -635,7 +635,7 @@

P

parsingArrayElement(String, String[]) - Method in class jrpc.clightning.CLightningRPC
 
-
parsingBitcoinOutputs(BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
+
parsingBitcoinOutputs(BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
 
pathSocket - Variable in class jrpc.service.socket.UnixDomainSocketRpc
 
@@ -719,9 +719,9 @@

T

 
txDiscard(String) - Method in class jrpc.clightning.CLightningRPC
 
-
txPrepare(String, String, BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
+
txPrepare(String, String, BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
 
-
txPrepare(BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
+
txPrepare(BitcoinOutput...) - Method in class jrpc.clightning.CLightningRPC
 
diff --git a/docs/jrpc/clightning/CLightningRPC.html b/docs/jrpc/clightning/CLightningRPC.html index a3ae49f..b5691d2 100644 --- a/docs/jrpc/clightning/CLightningRPC.html +++ b/docs/jrpc/clightning/CLightningRPC.html @@ -288,7 +288,7 @@

Method Summary

protected java.lang.String -
parsingBitcoinOutputs(BitcoinOutput... bitcoinOutputs)  +parsingBitcoinOutputs(BitcoinOutput... bitcoinOutputs)  CLightningPay @@ -310,11 +310,11 @@

Method Summary

CLightningBitcoinTx -txPrepare(BitcoinOutput... bitcoinOutputs)  +txPrepare(BitcoinOutput... bitcoinOutputs)  CLightningBitcoinTx -txPrepare(java.lang.String feerate, +txPrepare(java.lang.String feerate, java.lang.String minconf, BitcoinOutput... bitcoinOutputs)  @@ -494,7 +494,7 @@

autoCleanInvoice

java.lang.String expiredBy) - + - + - + diff --git a/docs/jrpc/clightning/model/types/CLightningChannelId.html b/docs/jrpc/clightning/model/types/CLightningChannelId.html index 3d2483a..e86c37e 100644 --- a/docs/jrpc/clightning/model/types/CLightningChannelId.html +++ b/docs/jrpc/clightning/model/types/CLightningChannelId.html @@ -99,7 +99,7 @@

Class CLightningChannelIdjava.lang.Object
    • -
    • jrpc.clightning.model.types.CLightningChannelId
    • +
    • jrpc.clightning.model.types.CLightningConnect
  • diff --git a/src/main/java/jrpc/clightning/CLightningRPC.java b/src/main/java/jrpc/clightning/CLightningRPC.java index 864e917..70a5329 100644 --- a/src/main/java/jrpc/clightning/CLightningRPC.java +++ b/src/main/java/jrpc/clightning/CLightningRPC.java @@ -1,17 +1,20 @@ /** - * Copyright 2019-2020 Vincenzo Palazzo vincenzo.palazzo@protonmail.com - *

    - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - *

    - * http://www.apache.org/licenses/LICENSE-2.0 - *

    - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. + * This is a wrapper for c-lightning RPC interface. + * Copyright (C) 2020 Vincenzo Palazzo vincenzopalazzodev@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ package jrpc.clightning; @@ -22,6 +25,7 @@ import jrpc.clightning.exceptions.CLightningException; import jrpc.clightning.model.*; import jrpc.clightning.model.types.*; +import jrpc.clightning.model.types.bitcoin.BitcoinOutput; import jrpc.clightning.service.socket.CLightningSocket; import jrpc.exceptions.ServiceException; import jrpc.service.CLightningLogger; @@ -383,7 +387,7 @@ public CLightningListFounds listFunds() { return (CLightningListFounds) mediatorCommand.runCommand(Command.LISTFOUNDS, payloadString); } - public String connect(String id, String host, String port) { + public CLightningConnect connect(String id, String host, String port) { if (id == null || id.trim().isEmpty()) { throw new CLightningException("The method connect have the parameter id is null or empty"); } @@ -410,11 +414,11 @@ public String connect(String id, String host, String port) { String payloadString = payload.toString(); CLightningLogger.getInstance().debug(TAG, "Payload for command connect is: " + payloadString); - CLightningChannelId channelId = (CLightningChannelId) mediatorCommand.runCommand(Command.CONNECT, payloadString); - return channelId.getId(); + CLightningConnect channelId = (CLightningConnect) mediatorCommand.runCommand(Command.CONNECT, payloadString); + return channelId; } - public String connect(String id) { + public CLightningConnect connect(String id) { if (id == null || id.trim().isEmpty()) { throw new CLightningException("The method connect have the parameter id is null or empty"); } @@ -621,8 +625,8 @@ public CLightningListPays listPays() { return this.listPays(""); } - public CLightningInvoice waitInvoice(String label){ - if(label == null){ + public CLightningInvoice waitInvoice(String label) { + if (label == null) { throw new CLightningException("The argument inside the method listPays is null"); } Map payload = new HashMap<>(); @@ -630,12 +634,12 @@ public CLightningInvoice waitInvoice(String label){ return (CLightningInvoice) mediatorCommand.runCommand(Command.WAITINVOICE, payload); } - public CLightningSendPay waitSendPay(String paymentHash){ + public CLightningSendPay waitSendPay(String paymentHash) { return this.waitSendPays(paymentHash, 0, 0); } - public CLightningSendPay waitSendPays(String paymentHash, int timeout, int partid){ - if(paymentHash == null){ + public CLightningSendPay waitSendPays(String paymentHash, int timeout, int partid) { + if (paymentHash == null) { throw new CLightningException("The argument {paymentHash} inside the method waitSendPays is null"); } doCheckPositiveNumber("waitSendPays", "timeout", timeout); @@ -643,16 +647,52 @@ public CLightningSendPay waitSendPays(String paymentHash, int timeout, int parti Map payload = new HashMap<>(); payload.put("payment_hash", paymentHash.trim()); - if(timeout > 0){ + if (timeout > 0) { payload.put("timeout", timeout); } - if (partid > 0){ + if (partid > 0) { payload.put("partid", partid); } return (CLightningSendPay) mediatorCommand.runCommand(Command.WAITSENDPAY, payload); } + public CLightningListNodes listNodes(String nodeId) { + doCheckString("listNodes", "nodeId", nodeId, true); + Map payload = new HashMap<>(); + if (!nodeId.trim().isEmpty()) { + payload.put("id", nodeId); + } + return (CLightningListNodes) mediatorCommand.runCommand(Command.LISTNODES, payload); + } + + public CLightningListNodes listNodes() { + return this.listNodes(""); + } + + public CLightningPing ping(String nodeId, int len, int pongBytes) { + doCheckString("ping", "ping", nodeId, true); + doCheckPositiveNumber("ping", "len", len); + doCheckPositiveNumber("ping", "pongBytes", pongBytes); + Map payload = new HashMap<>(); + + if (!nodeId.isEmpty()) { + payload.put("id", nodeId); + } + + payload.put("len", len); + payload.put("pongbytes", pongBytes); + return (CLightningPing) mediatorCommand.runCommand(Command.PING, payload); + } + + public CLightningPing ping(String nodeId) { + return this.ping(nodeId, 128, 128); + } + + public CLightningListTransactions listTransactions(){ + return (CLightningListTransactions) mediatorCommand.runCommand(Command.LISTTRANSACTIONS, new HashMap<>()); + } + //Register commands public void registerCommand(ICommandKey key, IRPCCommand command) { if (key == null || command == null) { throw new IllegalArgumentException("Key and/or command null"); @@ -666,13 +706,11 @@ public T runRegisterCommand(ICommandKey key, HashMap payload //Utility methods private void doCheckString(String command, String name, String value, boolean onlyNull) { - if (value == null || value.isEmpty()) { + if (value == null || (value.isEmpty() && !onlyNull)) { String message = "Propriety " + name + " in the command " + command; - if (name == null) { + if (value == null) { message += " null"; - } else if (onlyNull) { - return; //Good for the library - } else { + } else if (value.isEmpty() && !onlyNull) { message += " empty"; } throw new CLightningException(message); diff --git a/src/main/java/jrpc/clightning/commands/CLightningCommandConnect.java b/src/main/java/jrpc/clightning/commands/CLightningCommandConnect.java index 54baa39..2cb183b 100644 --- a/src/main/java/jrpc/clightning/commands/CLightningCommandConnect.java +++ b/src/main/java/jrpc/clightning/commands/CLightningCommandConnect.java @@ -16,7 +16,7 @@ package jrpc.clightning.commands; import com.google.gson.reflect.TypeToken; -import jrpc.clightning.model.types.CLightningChannelId; +import jrpc.clightning.model.types.CLightningConnect; import jrpc.wrapper.response.RPCResponseWrapper; import java.lang.reflect.Type; @@ -24,16 +24,14 @@ /** * @author https://github.com/vincenzopalazzo */ -public class CLightningCommandConnect extends AbstractRPCCommand{ - - private static final String COMMAND_NAME = "connect"; +public class CLightningCommandConnect extends AbstractRPCCommand{ public CLightningCommandConnect() { - super(COMMAND_NAME); + super(Command.CONNECT.getCommandKey()); } @Override protected Type toTypeFromClass() { - return new TypeToken>(){}.getType(); + return new TypeToken>(){}.getType(); } } diff --git a/src/main/java/jrpc/clightning/commands/CLightningCommandListTransactions.java b/src/main/java/jrpc/clightning/commands/CLightningCommandListTransactions.java new file mode 100644 index 0000000..e68e4cd --- /dev/null +++ b/src/main/java/jrpc/clightning/commands/CLightningCommandListTransactions.java @@ -0,0 +1,20 @@ +package jrpc.clightning.commands; + +import com.google.gson.reflect.TypeToken; +import jrpc.clightning.model.CLightningListTransactions; +import jrpc.clightning.model.types.CLightningPing; +import jrpc.wrapper.response.RPCResponseWrapper; + +import java.lang.reflect.Type; + +public class CLightningCommandListTransactions extends AbstractRPCCommand { + + public CLightningCommandListTransactions() { + super(Command.LISTTRANSACTIONS.getCommandKey()); + } + + @Override + protected Type toTypeFromClass() { + return new TypeToken>(){}.getType(); + } +} diff --git a/src/main/java/jrpc/clightning/commands/CLightningCommandPing.java b/src/main/java/jrpc/clightning/commands/CLightningCommandPing.java new file mode 100644 index 0000000..9abbbe9 --- /dev/null +++ b/src/main/java/jrpc/clightning/commands/CLightningCommandPing.java @@ -0,0 +1,19 @@ +package jrpc.clightning.commands; + +import com.google.gson.reflect.TypeToken; +import jrpc.clightning.model.types.CLightningPing; +import jrpc.wrapper.response.RPCResponseWrapper; + +import java.lang.reflect.Type; + +public class CLightningCommandPing extends AbstractRPCCommand{ + + public CLightningCommandPing() { + super(Command.PING.getCommandKey()); + } + + @Override + protected Type toTypeFromClass() { + return new TypeToken>(){}.getType(); + } +} diff --git a/src/main/java/jrpc/clightning/commands/Command.java b/src/main/java/jrpc/clightning/commands/Command.java index a868f09..a26dadd 100644 --- a/src/main/java/jrpc/clightning/commands/Command.java +++ b/src/main/java/jrpc/clightning/commands/Command.java @@ -42,12 +42,12 @@ public enum Command implements ICommandKey{ // ---------- NETWORK COMMANDS --------------- CONNECT("CONNECT"), // Supported DISCONNECT("DISCONNECT"), // Supported - LISTNODES("LISTNODES"), - LISTPEERS("LISTPEERS"), - PING("PING"), + LISTNODES("LISTNODES"), //Support + LISTPEERS("LISTPEERS"), //Support + PING("PING"), //Supported // ---------- PAYMENT COMMANDS --------------- - DECODEPAY("DECODEPAY"), + DECODEPAY("DECODEPAY"), //Suppoeted DELEXPIREDINVOICE("DELEXPIREDINVOICE"), DELINVOICE("DELINVOICE"), //SUPPORTED INVOICE("INVOICE"), //Supported @@ -57,6 +57,8 @@ public enum Command implements ICommandKey{ PAY("PAY"), //Supported WAITINVOICE("WAITINVOICE"), //supported WAITSENDPAY("WAITSENDPAY"), // Supported + LISTTRANSACTIONS("LISTTRANSACTIONS"), //Supported + // ---------- UTILITY COMMANDS --------------- GETINFO("GETINFO"), //Supported diff --git a/src/main/java/jrpc/clightning/commands/CommandRPCMediator.java b/src/main/java/jrpc/clightning/commands/CommandRPCMediator.java index 496882c..baea2cd 100644 --- a/src/main/java/jrpc/clightning/commands/CommandRPCMediator.java +++ b/src/main/java/jrpc/clightning/commands/CommandRPCMediator.java @@ -66,6 +66,8 @@ protected void initializeMediator() { commands.put(Command.STOP, new CLightningCommandStop()); commands.put(Command.LISTPAYS, new CLightningCommandListPays()); commands.put(Command.WAITINVOICE, new CLightningCommandWaitingInvoice()); + commands.put(Command.PING, new CLightningCommandPing()); + commands.put(Command.LISTTRANSACTIONS, new CLightningCommandListTransactions()); } @Deprecated diff --git a/src/main/java/jrpc/clightning/exceptions/CommandException.java b/src/main/java/jrpc/clightning/exceptions/CommandException.java index a82da6b..1efa959 100644 --- a/src/main/java/jrpc/clightning/exceptions/CommandException.java +++ b/src/main/java/jrpc/clightning/exceptions/CommandException.java @@ -19,8 +19,6 @@ * @author https://github.com/vincenzopalazzo */ public class CommandException extends RuntimeException{ - public CommandException() { - } public CommandException(String message) { super(message); diff --git a/src/main/java/jrpc/clightning/model/CLightningListTransactions.java b/src/main/java/jrpc/clightning/model/CLightningListTransactions.java new file mode 100644 index 0000000..5dad1fe --- /dev/null +++ b/src/main/java/jrpc/clightning/model/CLightningListTransactions.java @@ -0,0 +1,15 @@ +package jrpc.clightning.model; + +import jrpc.clightning.model.types.bitcoin.CLightningRawTransactions; + +import java.util.ArrayList; +import java.util.List; + +public class CLightningListTransactions { + + private List transactions = new ArrayList<>(); + + public List getTransactions() { + return transactions; + } +} diff --git a/src/main/java/jrpc/clightning/model/CLightningProprietiesMediator.java b/src/main/java/jrpc/clightning/model/CLightningProprietiesMediator.java index 58848f8..1d7f3a3 100644 --- a/src/main/java/jrpc/clightning/model/CLightningProprietiesMediator.java +++ b/src/main/java/jrpc/clightning/model/CLightningProprietiesMediator.java @@ -1,5 +1,8 @@ package jrpc.clightning.model; +import jrpc.clightning.exceptions.CLightningException; +import jrpc.clightning.plugins.exceptions.CLightningPluginException; + import java.util.HashMap; import java.util.Map; @@ -25,10 +28,12 @@ public void store(String key, Object value){ this.repository.put(key, value); } - public Object getValue(String key){ - //TODO check value + public T getValue(String key){ + if(key == null || key.isEmpty()){ + throw new CLightningException("Key inside the CLightningProprietiesMediator null"); + } if(this.repository.containsKey(key)){ - return this.repository.get(key); + return (T)this.repository.get(key); } return null; } @@ -36,4 +41,8 @@ public Object getValue(String key){ public boolean containsValue(String key){ return this.repository.containsKey(key); } + + public void clean(){ + this.repository.clear(); + } } diff --git a/src/main/java/jrpc/clightning/model/types/CLightningChannelId.java b/src/main/java/jrpc/clightning/model/types/CLightningConnect.java similarity index 93% rename from src/main/java/jrpc/clightning/model/types/CLightningChannelId.java rename to src/main/java/jrpc/clightning/model/types/CLightningConnect.java index 27df219..f7f0bf0 100644 --- a/src/main/java/jrpc/clightning/model/types/CLightningChannelId.java +++ b/src/main/java/jrpc/clightning/model/types/CLightningConnect.java @@ -18,9 +18,9 @@ /** * @author https://github.com/vincenzopalazzo */ -public class CLightningChannelId { +public class CLightningConnect { - String id; + private String id; public String getId() { return id; diff --git a/src/main/java/jrpc/clightning/model/types/CLightningPing.java b/src/main/java/jrpc/clightning/model/types/CLightningPing.java new file mode 100644 index 0000000..7125c31 --- /dev/null +++ b/src/main/java/jrpc/clightning/model/types/CLightningPing.java @@ -0,0 +1,13 @@ +package jrpc.clightning.model.types; + +import com.google.gson.annotations.SerializedName; + +public class CLightningPing { + + @SerializedName("totlen") + private int totLen; + + public int getTotLen() { + return totLen; + } +} diff --git a/src/main/java/jrpc/clightning/model/types/BitcoinOutput.java b/src/main/java/jrpc/clightning/model/types/bitcoin/BitcoinOutput.java similarity index 87% rename from src/main/java/jrpc/clightning/model/types/BitcoinOutput.java rename to src/main/java/jrpc/clightning/model/types/bitcoin/BitcoinOutput.java index 2a3edf9..43e1af6 100644 --- a/src/main/java/jrpc/clightning/model/types/BitcoinOutput.java +++ b/src/main/java/jrpc/clightning/model/types/bitcoin/BitcoinOutput.java @@ -13,14 +13,13 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package jrpc.clightning.model.types; +package jrpc.clightning.model.types.bitcoin; /** * @author https://github.com/vincenzopalazzo */ public class BitcoinOutput { - //TODO FIXME when run the command txprepare I have this error - // The output format must be {destination: amount} + private String address; private String amount = "all"; diff --git a/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningRawTransactions.java b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningRawTransactions.java new file mode 100644 index 0000000..b735979 --- /dev/null +++ b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningRawTransactions.java @@ -0,0 +1,53 @@ +package jrpc.clightning.model.types.bitcoin; + +import com.google.gson.annotations.SerializedName; + +import java.util.ArrayList; +import java.util.List; + +public class CLightningRawTransactions { + + private String hash; + private String rawtx; + @SerializedName("blockheight") + private int blockHeight; + @SerializedName("txindex") + private int txIndex; + @SerializedName("locktime") + private int locktime; + private int version; + private List inputs = new ArrayList<>(); + private List outputs = new ArrayList<>(); + + public String getHash() { + return hash; + } + + public String getRawtx() { + return rawtx; + } + + public int getBlockHeight() { + return blockHeight; + } + + public int getTxIndex() { + return txIndex; + } + + public int getLocktime() { + return locktime; + } + + public int getVersion() { + return version; + } + + public List getInputs() { + return inputs; + } + + public List getOutputs() { + return outputs; + } +} diff --git a/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionInput.java b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionInput.java new file mode 100644 index 0000000..3930244 --- /dev/null +++ b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionInput.java @@ -0,0 +1,25 @@ +package jrpc.clightning.model.types.bitcoin; + +import com.google.gson.annotations.SerializedName; + +import java.math.BigInteger; + +public class CLightningTransactionInput { + + @SerializedName("txid") + private String txId; + private int index; + private BigInteger sequences; + + public String getTxId() { + return txId; + } + + public int getIndex() { + return index; + } + + public BigInteger getSequences() { + return sequences; + } +} diff --git a/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionOutput.java b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionOutput.java new file mode 100644 index 0000000..0347c6c --- /dev/null +++ b/src/main/java/jrpc/clightning/model/types/bitcoin/CLightningTransactionOutput.java @@ -0,0 +1,20 @@ +package jrpc.clightning.model.types.bitcoin; + +public class CLightningTransactionOutput { + + private int index; + private String satoshis; + private String scriptPubKey; + + public int getIndex() { + return index; + } + + public String getSatoshis() { + return satoshis; + } + + public String getScriptPubKey() { + return scriptPubKey; + } +} diff --git a/src/main/java/jrpc/clightning/plugins/CLightningPlugin.java b/src/main/java/jrpc/clightning/plugins/CLightningPlugin.java index c476bc6..920f41d 100644 --- a/src/main/java/jrpc/clightning/plugins/CLightningPlugin.java +++ b/src/main/java/jrpc/clightning/plugins/CLightningPlugin.java @@ -1,32 +1,55 @@ +/** + * This is a wrapper for c-lightning RPC interface. + * Copyright (C) 2020 Vincenzo Palazzo vincenzopalazzodev@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ package jrpc.clightning.plugins; import com.google.gson.JsonObject; import com.google.gson.JsonParser; import com.google.gson.annotations.Expose; import jrpc.clightning.plugins.annotation.Hook; +import jrpc.clightning.plugins.annotation.PluginOption; import jrpc.clightning.plugins.annotation.RPCMethod; import jrpc.clightning.plugins.annotation.Subscription; import jrpc.clightning.plugins.log.CLightningLevelLog; import jrpc.clightning.plugins.rpcmethods.AbstractRPCMethod; -import jrpc.clightning.plugins.rpcmethods.ICLightningRPCMethod; import jrpc.clightning.plugins.rpcmethods.RPCMethodReflection; import jrpc.clightning.plugins.rpcmethods.RPCMethodType; import jrpc.clightning.plugins.rpcmethods.init.InitMethod; import jrpc.clightning.plugins.rpcmethods.manifest.ManifestMethod; +import jrpc.clightning.plugins.rpcmethods.manifest.types.Option; import jrpc.exceptions.ServiceException; import jrpc.service.CLightningLogger; import jrpc.service.converters.IConverter; import jrpc.service.converters.JsonConverter; import jrpc.service.converters.jsonwrapper.CLightningJsonObject; import org.reflections.Reflections; +import org.reflections.scanners.FieldAnnotationsScanner; import org.reflections.scanners.MethodAnnotationsScanner; import org.reflections.util.ClasspathHelper; import org.reflections.util.ConfigurationBuilder; import java.io.*; +import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; +import java.util.HashMap; import java.util.List; +import java.util.Map; import java.util.StringTokenizer; /** @@ -39,18 +62,21 @@ public abstract class CLightningPlugin implements ICLightningPlugin { private ManifestMethod manifest; @Expose + protected Map parameters; + @Expose private BufferedWriter stdout; @Expose private BufferedReader stdin; @Expose private Reflections reflections = new Reflections(new ConfigurationBuilder() .setUrls(ClasspathHelper.forPackage("jrpc.clightning.plugins")) - .setScanners(new MethodAnnotationsScanner())); + .setScanners(new MethodAnnotationsScanner(), new FieldAnnotationsScanner())); public CLightningPlugin() { this.manifest = new ManifestMethod(); this.stdin = new BufferedReader(new InputStreamReader(System.in)); this.stdout = new BufferedWriter(new OutputStreamWriter(System.out)); + this.parameters = new HashMap<>(); } public void addRPCMethod(AbstractRPCMethod method){ @@ -58,9 +84,9 @@ public void addRPCMethod(AbstractRPCMethod method){ throw new IllegalArgumentException("Method object null"); } CLightningLogger.getInstance().debug(TAG,"Added method to list methods of plugin"); - if(method.getType().equals(RPCMethodType.HOOK)){ + if(method.getType() == RPCMethodType.HOOK){ this.manifest.addHook(method.getName()); - return; + log(CLightningLevelLog.WARNING, "ADD HOCK: " + method.getName()); } this.manifest.addMethod(method); } @@ -76,6 +102,7 @@ public void start() { } CLightningLogger.getInstance().debug(TAG, "Message from stdout: " + messageSocket); JsonObject object = JsonParser.parseString(messageSocket).getAsJsonObject(); + log(CLightningLevelLog.WARNING, "Request: " + object.toString()); if (!isRpcCall(object)) { continue; } @@ -147,11 +174,32 @@ public void log(CLightningLevelLog level, String logMessage) { protected void registerMethod(){ addRPCMethod(this.manifest); this.registerMethodsWithAnnotation(); + this.addOptionsWithAnnotation(); this.registerSubscriptionsWithAnnotation(); this.registerHooksWithAnnotation(); addRPCMethod(new InitMethod()); } + private void addOptionsWithAnnotation() { + log(CLightningLevelLog.WARNING, "add option annotated"); + for(Field field : reflections.getFieldsAnnotatedWith(PluginOption.class)){ + log(CLightningLevelLog.WARNING, "field annotated: " + field.getName()); + if(field.isAnnotationPresent(PluginOption.class)){ + log(CLightningLevelLog.WARNING, "Find a plugin option"); + PluginOption annotation = field.getAnnotation(PluginOption.class); + Option option = new Option(); + //TODO pull the value directly from the annotation propriety + option.setDefaultValue(annotation.defValue()); + option.setDescriptionOption(annotation.description()); + option.setName(annotation.name()); + option.setType(annotation.typeValue()); + option.setDeprecated(annotation.deprecated()); + this.manifest.addOption(option); + log(CLightningLevelLog.WARNING, option.getNamePlugin()); + } + } + } + private void registerMethodsWithAnnotation(){ for(Method method : reflections.getMethodsAnnotatedWith(jrpc.clightning.plugins.annotation.RPCMethod.class)){ if(method.isAnnotationPresent(jrpc.clightning.plugins.annotation.RPCMethod.class)){ @@ -177,13 +225,12 @@ private void registerSubscriptionsWithAnnotation(){ } private void registerHooksWithAnnotation(){ - for(Method method : reflections.getMethodsAnnotatedWith(Subscription.class)){ + for(Method method : reflections.getMethodsAnnotatedWith(Hook.class)){ if(method.isAnnotationPresent(Hook.class)){ Hook hook = method.getAnnotation(Hook.class); String hookEvent = hook.hook(); - RPCMethodReflection hookMethod = - new RPCMethodReflection(hookEvent, "", "", "", - RPCMethodType.HOOK, method); + RPCMethodReflection hookMethod = new RPCMethodReflection( + hookEvent, "", "", "", RPCMethodType.HOOK, method); this.addRPCMethod(hookMethod); } } @@ -202,7 +249,7 @@ private void doMethods(JsonObject request, BufferedWriter stdout) throws Service if (method == null || method.isEmpty()) { return; } - + log(CLightningLevelLog.WARNING, method); CLightningLogger.getInstance().debug(TAG, "c-lightning calls for method: ++++++ " + method + " ++++++"); for (AbstractRPCMethod rpcMethod : this.getRpcMethods()) { CLightningLogger.getInstance().debug(TAG, "Call method plugin ++++++ " + rpcMethod.getName() + " ++++++"); @@ -213,12 +260,13 @@ private void doMethods(JsonObject request, BufferedWriter stdout) throws Service CLightningJsonObject result = new CLightningJsonObject(); response.add("id", request.get("id")); response.add("jsonrpc", request.get("jsonrpc")); - rpcMethod.doRun(this, new CLightningJsonObject(request), result); //TODO I'm testing to pass the plugin inside the rpc method + rpcMethod.doRun(this, new CLightningJsonObject(request), result); CLightningLogger.getInstance().debug(TAG, "Plugin result ++++++ " + response + " ++++++"); //JsonElement jsonResult = (JsonElement) jsonConverter.deserialization(result, JsonElement.class); CLightningLogger.getInstance().debug(TAG, "Plugin result ++++++ " + response + " ++++++"); response.add("result", result.getWrapper()); CLightningLogger.getInstance().debug(TAG, "******** final answer: " + response.toString()); + log(CLightningLevelLog.WARNING, response.toString()); stdout.write(response.toString()); stdout.flush(); } @@ -229,6 +277,20 @@ public void addSubscription(String event){ manifest.addSubscriptions(event); } + public void addParameter(String key, Object value){ + this.parameters.put(key, value); + } + + public T getParameter(String key){ + if(key == null || key.isEmpty()){ + throw new IllegalArgumentException("Key is null or empty"); + } + if(parameters.containsKey(key)){ + return (T) parameters.get(key); + } + return null; + } + // getter method public List getRpcMethods() { return manifest.getRpcMethods(); diff --git a/src/main/java/jrpc/clightning/plugins/ICLightningPlugin.java b/src/main/java/jrpc/clightning/plugins/ICLightningPlugin.java index 80e5bcb..920d8d4 100644 --- a/src/main/java/jrpc/clightning/plugins/ICLightningPlugin.java +++ b/src/main/java/jrpc/clightning/plugins/ICLightningPlugin.java @@ -23,4 +23,9 @@ public interface ICLightningPlugin { boolean isDynamic(); void log(CLightningLevelLog level, String logMessage); + + void addParameter(String key, Object value); + + T getParameter(String key); + } diff --git a/src/main/java/jrpc/clightning/plugins/annotation/PluginOption.java b/src/main/java/jrpc/clightning/plugins/annotation/PluginOption.java new file mode 100644 index 0000000..9edf19b --- /dev/null +++ b/src/main/java/jrpc/clightning/plugins/annotation/PluginOption.java @@ -0,0 +1,16 @@ +package jrpc.clightning.plugins.annotation; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.FIELD) +public @interface PluginOption { + public String name(); + public String defValue() default ""; + public String typeValue() default "string"; + public String description(); + public boolean deprecated() default false; +} diff --git a/src/main/java/jrpc/clightning/plugins/rpcmethods/AbstractRPCMethod.java b/src/main/java/jrpc/clightning/plugins/rpcmethods/AbstractRPCMethod.java index 867afd7..9d2072f 100644 --- a/src/main/java/jrpc/clightning/plugins/rpcmethods/AbstractRPCMethod.java +++ b/src/main/java/jrpc/clightning/plugins/rpcmethods/AbstractRPCMethod.java @@ -1,17 +1,30 @@ +/** + * This is a wrapper for c-lightning RPC interface. + * Copyright (C) 2020 Vincenzo Palazzo vincenzopalazzodev@gmail.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ package jrpc.clightning.plugins.rpcmethods; -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; -import com.google.gson.JsonParser; -import com.google.gson.JsonPrimitive; import com.google.gson.annotations.Expose; import com.google.gson.annotations.SerializedName; -import jrpc.exceptions.ServiceException; -import jrpc.service.CLightningLogger; import jrpc.service.converters.IConverter; import jrpc.service.converters.JsonConverter; -import java.io.*; +import java.util.HashMap; +import java.util.Map; /** @@ -70,4 +83,6 @@ public String getLongDescription() { public RPCMethodType getType() { return type; } + + } diff --git a/src/main/java/jrpc/clightning/plugins/rpcmethods/ICLightningRPCMethod.java b/src/main/java/jrpc/clightning/plugins/rpcmethods/ICLightningRPCMethod.java index 27d383e..a6d8969 100644 --- a/src/main/java/jrpc/clightning/plugins/rpcmethods/ICLightningRPCMethod.java +++ b/src/main/java/jrpc/clightning/plugins/rpcmethods/ICLightningRPCMethod.java @@ -1,12 +1,8 @@ package jrpc.clightning.plugins.rpcmethods; -import com.google.gson.JsonObject; import jrpc.clightning.plugins.ICLightningPlugin; -import jrpc.clightning.plugins.exceptions.CLightningPluginException; import jrpc.service.converters.jsonwrapper.CLightningJsonObject; -import java.util.Map; - /** * @author https://github.com/vincenzopalazzo */ diff --git a/src/main/java/jrpc/clightning/plugins/rpcmethods/init/InitMethod.java b/src/main/java/jrpc/clightning/plugins/rpcmethods/init/InitMethod.java index 5f18e0f..87bf4d9 100644 --- a/src/main/java/jrpc/clightning/plugins/rpcmethods/init/InitMethod.java +++ b/src/main/java/jrpc/clightning/plugins/rpcmethods/init/InitMethod.java @@ -1,7 +1,9 @@ package jrpc.clightning.plugins.rpcmethods.init; import com.google.gson.JsonObject; +import com.google.gson.JsonPrimitive; import jrpc.clightning.plugins.ICLightningPlugin; +import jrpc.clightning.plugins.log.CLightningLevelLog; import jrpc.clightning.plugins.rpcmethods.AbstractRPCMethod; import jrpc.clightning.service.CLightningConfigurator; import jrpc.service.CLightningLogger; @@ -27,8 +29,30 @@ public void doRun(ICLightningPlugin plugin, CLightningJsonObject request, CLight CLightningLogger.getInstance().debug(TAG, "***** Config propriety " + config.toString() + " *****"); String rpcPath = config.get("lightning-dir").getAsString() + "/" + config.get("rpc-file").getAsString(); CLightningLogger.getInstance().debug(TAG, "***** Method init rpc file path " + rpcPath + " *****"); - CLightningConfigurator.getInstance().changeUrlRpcFile(rpcPath); //This method change the url inside the configurator to set the personal path from plugin. - //also this method ignore the variable startup, maybe I should be save this variable inside the mediator? + CLightningConfigurator.getInstance().changeUrlRpcFile(rpcPath); + + plugin.log(CLightningLevelLog.WARNING, jsonParams.toString()); + mappingParameters(plugin, jsonParams); + } + + private void mappingParameters(ICLightningPlugin plugin, JsonObject jsonParams) { + if(jsonParams == null){ + throw new IllegalArgumentException("jsonParams null"); + } + if(jsonParams.has("options")){ + JsonObject options = jsonParams.getAsJsonObject("options"); + options.keySet().forEach(key ->{ + JsonPrimitive value = options.get(key).getAsJsonPrimitive(); + plugin.log(CLightningLevelLog.WARNING,value.toString()); + if(value.isBoolean()){ + plugin.addParameter(key, value.getAsBoolean()); + }else if(value.isNumber()){ + plugin.addParameter(key, value.getAsInt()); + }else{ + plugin.addParameter(key, value.getAsString()); + } + }); + } } } diff --git a/src/main/java/jrpc/clightning/plugins/rpcmethods/manifest/ManifestMethod.java b/src/main/java/jrpc/clightning/plugins/rpcmethods/manifest/ManifestMethod.java index 02f97f1..8bf914b 100644 --- a/src/main/java/jrpc/clightning/plugins/rpcmethods/manifest/ManifestMethod.java +++ b/src/main/java/jrpc/clightning/plugins/rpcmethods/manifest/ManifestMethod.java @@ -6,7 +6,6 @@ import jrpc.clightning.model.CLightningProprietiesMediator; import jrpc.clightning.plugins.ICLightningPlugin; import jrpc.clightning.plugins.rpcmethods.AbstractRPCMethod; -import jrpc.clightning.plugins.rpcmethods.ICLightningRPCMethod; import jrpc.clightning.plugins.rpcmethods.init.InitMethod; import jrpc.clightning.plugins.rpcmethods.manifest.types.Features; import jrpc.clightning.plugins.rpcmethods.manifest.types.Option; @@ -22,7 +21,7 @@ */ public class ManifestMethod extends AbstractRPCMethod { - private static final Class TAG = ManifestMethod.class; + private static final Class TAG = ManifestMethod.class; private List