Commit Graph

4494 Commits

Author SHA1 Message Date
Pascal Bleser
f6df0be4ae groupware: add instructions for using stalwart-admin 2026-04-13 16:40:14 +02:00
Pascal Bleser
7af0f3e877 groupware: fix NPE when one of the accounts is a group account 2026-04-13 16:40:14 +02:00
Pascal Bleser
b7f07935fe groupware: DEVELOPER.md: add note explaining LDAPTLS_REQCERT 2026-04-13 16:40:14 +02:00
Pascal Bleser
c0377479b7 groupware: accept both '_' and '*' as the 'default account' placeholder 2026-04-13 16:40:14 +02:00
Pascal Bleser
7e084568c8 groupware: DEVELOPER.md: explain how to set a quota on a user using the Stalwart management API 2026-04-13 16:40:14 +02:00
Pascal Bleser
2d608ba50a groupware: add Mermaid diagrams to describe the two setup options 2026-04-13 16:40:13 +02:00
Pascal Bleser
59f2d95d86 groupware: implement email updating and email keyword updating endpoints 2026-04-13 16:40:13 +02:00
Pascal Bleser
67f9c0810f docs(groupware): upgrade @redocly/cli 2.3.1 -> 2.4.0 2026-04-13 16:40:13 +02:00
Pascal Bleser
f2ac0cdaeb groupware: further updates to make everything work with the builtin LDAP and OIDC 2026-04-13 16:40:13 +02:00
Pascal Bleser
0645f0bd6e groupware: for /accounts/all/emails/latest/summary, rename the ?unread query parameter into ?seen as that is more intuitive 2026-04-13 16:40:13 +02:00
Pascal Bleser
8a4745ed8d groupware: make everything also work with the built-in LDAP and IDP 2026-04-13 16:40:13 +02:00
Pascal Bleser
6c1c631b5a groupware: update @redocly/cli from 2.3.0 to 2.3.1 2026-04-13 16:40:13 +02:00
Pascal Bleser
2976bb7651 docs(groupware): fix basepath in OpenAPI, /groupware instead of /groupware/groupware 2026-04-13 16:40:13 +02:00
Viktor Scharf
97903ff74e fixed connection reset issue. adapted make file to generate swagger docs on mac 2026-04-13 16:40:13 +02:00
Pascal Bleser
5179942083 groupware: improve jmap integration tests
* use gofakeit instead of loremipsum, as it can also fake images for
   attachments

 * random emails for testing: generate threads, add attachments
2026-04-13 16:40:13 +02:00
Pascal Bleser
ca5167ddd8 groupware: add bootstrapping on / with quotas for all accounts 2026-04-13 16:40:13 +02:00
Pascal Bleser
768485f600 groupware: add /quota for all accounts 2026-04-13 16:40:13 +02:00
Pascal Bleser
856bcfb9a3 groupware: improve instructions in DEVELOPER.md 2026-04-13 16:40:13 +02:00
Pascal Bleser
e208e49966 groupware: update @redocly/cli: 2.2.2 -> 2.3.0 2026-04-13 16:40:13 +02:00
Pascal Bleser
1c754794f5 groupware: add quota API + add support for Accept-Language and Content-Language 2026-04-13 16:40:13 +02:00
Pascal Bleser
a7f9c41c53 groupware: minor improvements to the DEVELOPER.md 2026-04-13 16:40:13 +02:00
Pascal Bleser
d44ded1408 groupware: add flag to currently ignore session capability checks for calendars, contacts and tasks, as those are not implemented in Stalwart yet; will need to remove it in the future 2026-04-13 16:40:13 +02:00
Pascal Bleser
a2b406d451 groupware: add JMAP capability checking (in part: for contacts, calendars, tasks) 2026-04-13 16:40:13 +02:00
Pascal Bleser
0ae8360529 /auth: add SkipXAccessToken:true 2026-04-13 16:40:13 +02:00
Pascal Bleser
36c591376d groupware: add mock endpoints for tasklists and tasks 2026-04-13 16:40:13 +02:00
Pascal Bleser
cfdbcb89da groupware: implement JMAP Task specification 2026-04-13 16:40:13 +02:00
Pascal Bleser
6c37504c14 groupware: more mock data, added missing JMAP types 2026-04-13 16:40:13 +02:00
Pascal Bleser
2e3fa6ab97 groupware: add mock endpoints for addressbooks and contacts 2026-04-13 16:40:13 +02:00
Pascal Bleser
f4c7527097 services/groupware/DEVELOPER.md: adapt to new path for the opencloud_full deployment 2026-04-13 16:40:13 +02:00
Pascal Bleser
e9efc5894b Docker Compose Groupware improvements
* made a few changes in order to further simplify the setup for
   developers of the Groupware backend

 * add STALWART_DOMAIN to deployments/examples/opencloud_full/.env

 * adapt the Stalwart configuration file to not set server.hostname and,
   instead, pick it up from /etc/hostname, which is set by Docker
   Compose as we can use default values for STALWART_DOMAIN there, in an
   analogous fashion to the other containers in that project

 * add config/keycloak/clients/groupware.json to avoid requiring manual
   configuration of Keycloak via the admin web UI

 * Stalwart container:
   - listen for SMTPS on :1465
   - remove the stalwart-logs volume, not needed (logs are going to
     stdout)

 * updated services/groupware/DEVELOPER.md:
   - refer to a variable OCDIR to make instructions more copy-pasteable
   - remove manual Keycloak configuration section as it is now obsolete,
     replaced by provisioning a configuration file instead
2026-04-13 16:40:13 +02:00
Pascal Bleser
542d35e133 start websocket implementation, add endpoint for email summaries
* feat(groupware): start implementing JMAP websocket support for push
   notifications (unfinished)

 * groupware: add GetLatestEmailsSummaryForAllAccounts

 * add new vendored dependency: github.com/gorilla/websocket

 * jmap: add QueryEmailSummaries

 * openapi: start adding examples

 * openapi: add new tooling for api-examples.yaml injection

 * apidoc-process.ts: make it more typescript-y

 * bump @redocly/cli from 2.0.8 to latest 2.2.0
2026-04-13 16:40:13 +02:00
Pascal Bleser
9341c75d69 refactor(groupware): just use a function for the attachment picker
Minor: be more Go idiomatic: just use a function to pick the attachment
from an Email's attachment list instead of using an interface with
multiple iplementation structs.
2026-04-13 16:40:13 +02:00
Pascal Bleser
c2b69f79cf groupware: improved attachment APIs
* feat(groupware): add /accounts/{}/emails/{}/attachments

 * feat(groupware): add
   /accounts/{}/emails/{}/attachments?partId=&name=&blobId=
2026-04-13 16:40:13 +02:00
Pascal Bleser
9fff454131 fix(groupware): update DEVELOPER.md imap-filler usage since it was updated to use flags instead of environment variables 2026-04-13 16:40:13 +02:00
Pascal Bleser
6cee6e710e docs(groupware): more developer instructions 2026-04-13 16:40:13 +02:00
Pascal Bleser
8c10f2933b more updates to the Groupware DEVELOPER.md 2026-04-13 16:40:13 +02:00
Pascal Bleser
aa163d57fa docs(groupware): add configuration instructions to DEVELOPER.md 2026-04-13 16:40:13 +02:00
Pascal Bleser
5d02cab3e9 fix(groupware): fix JMAP error handling
* the JMAP error handling was not working properly, fixed it and added
   error definitions accordingly

 * add operations to retrieve mailbox roles and mailboxes by role for
   all accounts
2026-04-13 16:40:13 +02:00
Pascal Bleser
6db1809bf5 refactor(groupware): rename "Messages" to "Email" everywhere
There was really no reason to go with "Messages" as far as the
vocabulary of the Groupware API goes, since the objects those APIs serve
are "Emails", to stick with the wording of the JMAP specification.
2026-04-13 16:40:13 +02:00
Pascal Bleser
1c615a5461 docs(groupware): add services/groupware/DEVELOPER.md 2026-04-13 16:40:13 +02:00
Pascal Bleser
8622bba3db groupware: minor typo fixes 2026-04-13 16:40:13 +02:00
Pascal Bleser
2c8784bb83 feat(groupware): add fetching all mailboxes for all accounts
* add URL to retrieve all the mailboxes for all the accounts of a user,
   as a first use-case for an all-accounts operation, as
   /accounts/all/mailboxes

 * add URL to retrieve mailbox changes for all the mailboxes of all the
   accounts of a user, as a first use-case for an all-accounts
   operation, as /accounts/all/mailboxes/changes

 * change the defaultAccountId from '*' to '_', as '*' rather indicates
   "all" than "default", and we might want to use that for "all
   accounts" operations in the future

 * refactor(groupware): remove the accountId parameter from the logger()
   function, as it is not used anyways, but also confusing for
   operations that support multiple account ids
2026-04-13 16:40:12 +02:00
Pascal Bleser
fe1606e712 docs(groupware): OpenAPI improvements
* refactor some pkg/jmap and groupware methods to make more sense from
   an API point-of-view

 * add path parameter documentation, but automate it by injecting their
   definition into the OpenAPI YAML tree that is extracted from the
   source code using go-swagger as it is too cumbersome, repetitive and
   error-prine to document them in the source code; wrote a TypeScript
   file apidoc-process.ts to do so

 * add generating an offline HTML file for the OpenAPI documentation
   using redocly, and injecting a favicon into the resulting HTML; wrote
   a TypeScript file apidoc-postprocess-html.ts to do so
2026-04-13 16:40:12 +02:00
Pascal Bleser
0a406aeec1 refactor(groupware): session cache and DNS autodiscovery
* move the logging of the username and session state away from pkg/jmap
   and into services/groupware

 * introduce more decoupling for the session cache, as well as moving
   the implementation into groupware_session.go
2026-04-13 16:39:51 +02:00
Pascal Bleser
3a37108637 groupware: add DNS auto-discovery (currently disabled, needs testing) 2026-04-13 16:39:51 +02:00
Pascal Bleser
cc870e69e6 groupware: session handling improvements
* remove the baseurl from the JMAP client configuration, and pass it to
   the session retrieval functions instead, as that is really the only
   place where it is relevant, and we gain flexibility to discover that
   session URL differently in the future without having to touch the
   JMAP client

 * move the default account identifier handling from the JMAP package to
   the Groupware one, as it really has nothing to do with JMAP itself,
   and is an opinionated feature of the Groupware REST API instead

 * add an event listener interface for JMAP events to be more flexible
   and universal, typically for metrics that are defined on the API
   level that uses the JMAP client

 * add errors for when default accounts cannot be determined

 * split groupware_framework.go into groupware_framework.go,
   groupware_request.go and groupware_response.go

 * move the accountId logging into the Groupware level instead of JMAP
   since it can also be relevant to other operations that might be
   worthy of logging before the JMAP client is even invoked
2026-04-13 16:39:51 +02:00
Pascal Bleser
a38d8b7ffa groupware: fix debug server, was missing a lot of configuration options and was binding to :80 2026-04-13 16:39:51 +02:00
Pascal Bleser
aaf94d32be refactor(groupware): logging and metrics improvements
* some minor code refactorings to improve logging and metrics

 * more code documentation
2026-04-13 16:39:51 +02:00
Pascal Bleser
baebc91b8d groupware: improve metrics
* implement more metrics, in a more streamlined fashion

 * use concurrent-map to store SSE streams instead of a regular map with
   one big lock that will not scale when it grows, causing too much
   contention on that one lock

 * while testing error metrics, noticed a few bugs with error handling
   when Stalwart is down: fixed
2026-04-13 16:39:51 +02:00
Pascal Bleser
934178ae6a groupware: implement metrics
* implement a framework for metrics, with a few exemplary ones
2026-04-13 16:39:51 +02:00