1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00
Go to file
Michael Vetter c9b154b1a2 database: Only insert if there is no entry with same archive_id
archive_is is <stanza-id> or <result id=""> and should identify one
message stable and uniquely.

See XEP-0359: Unique and Stable Stanza IDs.

We need this for example for this situation:
* we go online with Profanity
* we fetch all messages since yesterday
* we add them to the db
* we go offline
* we go online with Profanity
* we fetch all messages since yesterday
* we only want to add the new ones

So far we don't ask MAM "give me all since last 'id'" but since a
certain date.

In case no archive_id will be set, it will be `(null)` and thus should
be inserted anyways because it won't find a value with (null) in that
row.

Because when adding we use `message->stanzaid ? message->stanzaid : "",`
so it will be empty in such a case.

Regards MAM: https://github.com/profanity-im/profanity/issues/660
Regards Stable IDs: https://github.com/profanity-im/profanity/issues/1207
2020-07-23 15:23:18 +02:00
.builds Bump OpenBSD build to 6.7 2020-06-06 11:53:24 +02:00
.github Lift 50 issues ban :-) 2020-02-03 16:25:10 +01:00
apidocs Update copyright 2018-01-21 15:00:02 +00:00
docs 0.9.5 2020-07-01 18:47:07 +02:00
icons better, final icons 2016-03-09 12:55:57 +01:00
src database: Only insert if there is no entry with same archive_id 2020-07-23 15:23:18 +02:00
tests Merge branch 'master' of github.com:profanity-im/profanity 2020-07-10 13:46:06 +02:00
themes Remove unanimous MAM display 2020-04-25 17:19:02 +02:00
.clang-format clang-format: Dont sort includes 2020-07-07 14:18:37 +02:00
.gitignore Add zipfiles to gitignore 2020-02-03 16:25:50 +01:00
.travis.yml Ubuntu Latest (20.04 currently) in CI 2020-07-10 14:14:04 +02:00
bootstrap.sh Add Travis CI tests for Arch, Debian and OSX/macOS 2019-06-06 13:58:26 +02:00
Brewfile.travis Add sqlite to CI dependencies 2020-04-06 10:50:20 +02:00
CHANGELOG Update 0.9.5 changelog 2020-07-01 18:41:46 +02:00
ci-build.sh Fallback for nproc for systems without GNU coreutils 2020-04-01 14:21:12 +02:00
configure-debug Include python plugins by default in build 2016-07-24 01:34:02 +01:00
configure-plugins Added python plugins code 2016-02-24 00:31:55 +00:00
configure.ac 0.9.5 2020-07-01 18:47:07 +02:00
CONTRIBUTING.md Add filetype check to pre hook example 2020-07-15 11:36:39 +02:00
COPYING Added GPL 2012-02-20 20:07:38 +00:00
Dockerfile.arch Change to .tar.zst archives that latest Arch devtools uses 2020-07-20 10:52:12 +02:00
Dockerfile.debian Add sqlite to CI dependencies 2020-04-06 10:50:20 +02:00
Dockerfile.fedora Add Fedora travis CI 2020-04-17 15:46:55 +02:00
Dockerfile.tumbleweed ci os tw: disable building of stabber 2020-07-08 13:03:19 +02:00
Dockerfile.ubuntu Ubuntu Latest (20.04 currently) in CI 2020-07-10 14:14:04 +02:00
LICENSE.txt Update copyright years 2019-04-24 01:08:38 +02:00
Makefile.am Remove /tiny command 2020-07-10 17:48:34 +02:00
prof.supp Dirty fix libgcrypt memleak 2019-07-11 14:25:42 +02:00
profanity.spec Update dependencies in spec files 2020-04-07 11:39:17 +02:00
profrc.example XEP-0392: config: add "color.nick" bool option 2019-12-03 21:10:39 +01:00
README.md readme: add link to contributing.md 2020-07-07 14:21:01 +02:00
RELEASE_GUIDE.md Mention profnaity_version in release guide 2020-07-09 17:03:05 +02:00
SPONSORS.md Update readme and sponsors 2020-05-27 10:13:24 +02:00
theme_template Make 'scrolled' themeable 2020-05-21 09:16:18 +02:00

Profanity

Build Status builds.sr.ht status Chat Packaging status GitHub contributors

Profanity is a console based XMPP client inspired by Irssi.

If you like Profanity consider becoming a sponsor or donate some money.

alt tag

See the User Guide for information on installing and using Profanity.

Project

This project is about freedom, privacy and choice. We want to enable people to chat with one another in a safe way. Thus supporting encryption (OTR, PGP, OMEMO) and being decentralized, meaning everyone can run their own server. We believe XMPP is a great proven protocol with an excellent community serving this purpose well.

Feel free to follow us on twitter, join our mailing list and/or MUC.

Installation

Our user guide contains an install section and a section for building from source yourself.

Donations

We would highly appreciate it if you support us via GitHub Sponsors. Especially if you make feature requests or need help using Profanity. Sponsoring enables us to spend time on Profanity.

GitHub matches every donation in the first year.

An alternative way to support us would be via Patreon or ask for our IBAN.

Issues backed by a sponsor will be tagged with the sponsored label. Feature requests that we consider out of scope, either because of interest or because of time needed to implement them, will be marked with the unfunded label.

Another way to sponsor us or get an issue solved is to create a bug bounty. Here one sets a bounty on a certain task and once the task is completed you send the money to the person who did the work.

Tasks from our sponsors will be tackled first.

Thank you! <3

How to contribute

We tried to sum things up on our helpout page. Additionally you can check out our blog where we have articles like: How to get a backtrace and Contributing a Patch via GitHub. For more technical details check out our CONTRIBUTING.md file.

Getting help

To get help, first read our User Guide then check out the FAQ. If you have are having a problem then first search the issue tracker. If you don't find anything there either come to our MUC or create a new issue depending on what your problem is.

Website

URL: https://profanity-im.github.io

Repo: https://github.com/profanity-im/profanity-im.github.io

Blog

URL: https://profanity-im.github.io/blog

Repo: https://github.com/profanity-im/blog

Mailinglist

Mailing List: https://lists.notraces.net/mailman/listinfo/profanity

Thanks to @toogley!

Chatroom

MUC: profanity@rooms.dismail.de

Plugins

Plugins repository: https://github.com/profanity-im/profanity-plugins