weechat-xmpp/README.org
Tony Olagbaiye 9c03d4d660
carbons
2021-07-16 03:44:46 +01:00

5.4 KiB
Raw Blame History

weechat-xmpp

file:https://api.travis-ci.org/bqv/weechat-xmpp.svg?branch=master file:https://coveralls.io/repos/github/bqv/weechat-xmpp/badge.svg?branch=master https://img.shields.io/github/issues/bqv/weechat-xmpp.svg https://img.shields.io/github/issues-closed/bqv/weechat-xmpp.svg https://img.shields.io/github/license/bqv/weechat-xmpp.svg https://img.shields.io/badge/weechat--extras-xmpp-blue.svg file:https://inverse.chat/badge.svg?room=weechat@muc.xa0.uk

Status: XMPP for power users and digital masochists
Location: http://github.com/bqv/weechat-xmpp
Version: 0.1.1
Disclaimer: I'm lazy and unashamedly clinically insane

Description

A weechat plugin in C to extend the chat client to support XMPP and a currently minimal but ideally maximal set of XEPs.

Usage

  1. Start with /xmpp add, use /help xmpp for instructions.
  2. Use /xmpp connect <account-name> with the name set at add-time.

Installing

Place xmpp.so in the appropriate place for weechat plugins.

Dependencies

  • libstrophe (dynamic, dependency)
  • libxml2 (dynamic, dependency)
  • glib (dynamic, dependency of libomemo)
  • sqlite (dynamic, dependency of libomemo/axc)
  • libsignal-protocol-c (dynamic, dependency of axc)
  • weechat (>= v3.0)

.. or just use the guix spec in .envrc

Building

git clone git://github.com/bqv/weechat-xmpp.git
cd weechat-xmpp
git submodule update --init --recursive
make
make install

Do NOT run make install as root, it installs the plugin to your local weechat plugins directory

Development

I use emacs for development of this, although I am also a fan of vim. My debug build process involves static analysis with clang and cppcheck, and dynamic analysis with address-sanitizer and leak-sanitizer. My debug evaluation process involves gdb/mi run with the arguments -ex "handle SIGPIPE nostop noprint pass" --args weechat -a 2>asan.log since part of weechat and it's default plugins use SIGPIPE as control.

I have no real requests for style of pull requests besides a wish that you keep vaguely to the indentation style I use for this project.

Happy coding!

Tasks

DONE [A] Implement basic functionality (milestone v0.1)

  • Connecting
  • Pretty-printing stanzas
  • Receiveing and formatting PMs to a dedicated buffer
  • Responding to PMs and formatting responses
  • Opening PMs (/chat)

TODO [A] Implement essential functionality (milestone v0.2)

  • Opening PMs with initial message
  • OOB messages

    • Single media on a line
    • Multiple media inline (protocol?)
  • Buffer autoswitch on enter/open
  • Handle open/enter jids with a resource without breaking
  • Allow /close without crashing
  • [#B] Handle wide errors gracefully

    • [#B] Event-driven MUC entrance
  • [#C] XMPP Ping (xep-199)
  • [#A] Highlight
  • MUCs

    • Opening (/enter)
    • [#B] Leave on /close
    • Receiving
    • Sending

      • With /msg
    • [#B] Edits

      • [#B] Displaying
      • [#B] Tagging
      • [#B] Making
      • [#C] Diff highlighting
    • [#B] Handle errors gracefully
    • [#B] Presence/nicklist

      • [#B] Enters
      • [#B] Leaves
      • [#B] Tracking
    • [#B] Set/show topic
  • OMEMO (libsignal-protocol-c / axc)

    • Presence

      • Disco
      • Disco response
      • Key Generation / storage (secured_data?)

        • Generation
        • Storage
        • Announce
    • Messages
  • [#C] MUC PMs
  • [#A] Send typing notifications
  • [#A] Recv typing notifications
  • [#C] Read receipts
  • Message Carbons
  • Service Disco
  • Bookmarks / Roster

    • Autojoin bookmarks
    • Add bookmarks
    • Delete bookmarks
    • Roster
  • OTR (libotr)
  • PGP (libgpgme)
  • Room Explorer (https://search.jabber.network/docs/api)

TODO [C] Implement completion engine (milestone v0.3)

TODO [#D] Close all issues (milestone v1.0)

  • Absorb libomemo / axc, and drop glib

Contributing

Your contributions are always welcome! Please submit a pull request or create an issue to add a new or missing feature.

Testemonials

"Weechat-Strophe - for the discerning dual IRCer XMPPer" Ellenor et al Bjornsdottir

License

weechat-xmpp is licensed under the Mozilla Public License Version 2.0 available here and in LICENSE.