kdeconnect-kde/plugins
Alexander Lohnau 1631ada5b3 Simplify KDEConnectPlugin::recievePacket
- We do not need the return type. If a plugin declares it can handle the
  packet it should do so. We don't have any fallback logic in place and
  the packet types are namespaced with the plugin IDs anyway.

- Provide a default implementation with a warning, not all plugins need
  to overwrite this
2023-08-03 20:49:44 +02:00
..
battery Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
bigscreen Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
clipboard Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
connectivity-report Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
contacts Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
findmyphone Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
findthisdevice Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
lockdevice Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
mmtelephony Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
mousepad Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
mpriscontrol Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
mprisremote Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
notifications Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
pausemusic Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
photo Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
ping Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
presenter Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
remotecommands Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
remotecontrol Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
remotekeyboard Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
remotesystemvolume Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
runcommand Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
screensaver-inhibit Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
sendnotifications Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
sftp Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
share Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
sms Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
systemvolume Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
telephony Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
virtualmonitor Simplify KDEConnectPlugin::recievePacket 2023-08-03 20:49:44 +02:00
CMakeLists.txt Actually fix the MacOS build 2023-07-31 23:04:08 +02:00
kdeconnect.notifyrc SVN_SILENT made messages (.desktop file) - always resolve ours 2023-08-01 01:39:50 +00:00
Messages.sh Figure out Messages.sh after code refactoring 2014-06-17 18:45:47 +02:00
README.txt Fix file name on plugin's readme. 2022-11-27 01:40:51 +00:00

Writing a plugin for KDE Connect
=================================

For the desktop client (this project):
--------------------------------------

1. Enter the "plugins" directory.
2. Copy the "ping" under a different name ("findmyphone" in this example).
3. Add "add_subdirectory(findmyphone)" to CMakeLists.txt after the others "add_subdirectory".
4. Enter the new "findmyphone" directory.
5. Edit CMakeLists.txt by replacing "ping" with "findmyphone".
6. Rename other files in this directory by replacing "ping" with "findmyphone"
7. Write a description of your plugin into "README"
8. Edit findmyphoneplugin.cpp and findmyphoneplugin.h.
  A. Change license header.
  B. Replace (case sensitive) "ping" with "findmyphone", "PingPlugin" with "FindMyPhonePlugin" and "PING" with "FINDMYPHONE".
9. Edit kdeconnect_findmyphone.json file:
  A. Replace "ping" with "findmyphone".
  B. Change name, description, icon, author, email, version, website, license info.
  C. Remove all the translations
  D. Set X-KDEConnect-SupportedPacketType and X-KDEConnect-OutgoingPacketType to the packet type your plugin will receive
     and send, respectively. In this example this is "kdeconnect.findmyphone". Make sure that this matches what is defined in
     the findmyphoneplugin.h file (in the line "#define PACKET_TYPE_..."), and also in Android.
10. Now you have an empty skeleton to implement your new plugin logic.

For Android (project kdeconnect-android):
-----------------------------------------

1. Change directory to src/org/kde/kdeconnect/Plugins.
2. Copy "PingPlugin" under a different name ("FindMyPhonePlugin" in this example).
3. Enter the new "FindMyPhonePlugin" directory.
4. Rename "PingPlugin.java" to "FindMyPhonePlugin.java"
5. Edit it. Replace (case sensitive) "Ping" with "FindMyPhone", "ping" with "findmyphone", "PING" with "FINDMYPHONE"
   and "plugin_ping" with "plugin_findmyphone".
6. Open res/values/strings.xml. Find and copy the lines "pref_plugin_ping_desc" and "pref_plugin_ping" replacing "ping"
   with "findmyphone" and edit the plugin name and description between <string> </string>).
7. Now you have an empty skeleton to implement your new plugin logic.