Commit Graph

22733 Commits

Author SHA1 Message Date
Pascal Bleser
940cd81083 groupware: add /quota for all accounts 2026-01-22 09:42:23 +01:00
Pascal Bleser
fb466a4132 groupware: improve instructions in DEVELOPER.md 2026-01-22 09:42:23 +01:00
Pascal Bleser
b11ac4b90a groupware: update @redocly/cli: 2.2.2 -> 2.3.0 2026-01-22 09:42:22 +01:00
Pascal Bleser
deee6102ec groupware: add quota API + add support for Accept-Language and Content-Language 2026-01-22 09:42:22 +01:00
Pascal Bleser
36cf2c323e groupware: minor improvements to the DEVELOPER.md 2026-01-22 09:42:22 +01:00
Pascal Bleser
9febfab9b6 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-01-22 09:42:22 +01:00
Pascal Bleser
5dc89de7ef groupware: add JMAP capability checking (in part: for contacts, calendars, tasks) 2026-01-22 09:42:22 +01:00
Pascal Bleser
0b334fc5e1 /auth: add SkipXAccessToken:true 2026-01-22 09:42:22 +01:00
Pascal Bleser
d6e269abb8 groupware: add mock endpoints for tasklists and tasks 2026-01-22 09:42:22 +01:00
Pascal Bleser
55d521d15d groupware: implement JMAP Task specification 2026-01-22 09:42:22 +01:00
Pascal Bleser
5df0ec0e25 groupware: more mock data, added missing JMAP types 2026-01-22 09:42:22 +01:00
Pascal Bleser
d9878b38eb groupware: add mock endpoints for addressbooks and contacts 2026-01-22 09:42:22 +01:00
Pascal Bleser
20980a6037 opencloud_full: also keep the 'Trace-Id' HTTP header 2026-01-22 09:42:22 +01:00
Pascal Bleser
e71508b30c implement JSCalendar (RFC 8984) 2026-01-22 09:42:22 +01:00
Pascal Bleser
3720851da3 services/groupware/DEVELOPER.md: adapt to new path for the opencloud_full deployment 2026-01-22 09:42:22 +01:00
Pascal Bleser
944abd8f57 JSContact: refactored after full test coverage, stronger typing for enumerations 2026-01-22 09:42:22 +01:00
Pascal Bleser
e754b5a718 Implement JSContact (RFC9553) Model
* add pkg/jscontact with the implementation of the RFC9553 data model

 * add JMAP Calendar session capabilities support in pkg/jmap
2026-01-22 09:42:22 +01:00
Pascal Bleser
917fb38e1c 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-01-22 09:42:22 +01:00
Pascal Bleser
6db8dd3956 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-01-22 09:42:22 +01:00
Pascal Bleser
63fad66258 feat(groupware): add WebsocketEndpoint to the JMAP Session 2026-01-22 09:42:22 +01:00
Pascal Bleser
738bef1e31 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-01-22 09:42:22 +01:00
Pascal Bleser
07894319c5 groupware: improved attachment APIs
* feat(groupware): add /accounts/{}/emails/{}/attachments

 * feat(groupware): add
   /accounts/{}/emails/{}/attachments?partId=&name=&blobId=
2026-01-22 09:42:22 +01:00
Pascal Bleser
c7c5dca112 jmap: modify GetBlob -> GetBlobMetadata
* fix(jmap): fix bug where CommandBlobUpload was used instead of
   CommandBlobGet in GetBlob (now GetBlobMetadata)

 * we currently don't need a variant of BlobGetCommand that also
   retrieves the content of the blob, instead we only use it for
   retrieving metadata about it
2026-01-22 09:42:22 +01:00
Pascal Bleser
1efa53ce0e fix(groupware): update DEVELOPER.md imap-filler usage since it was updated to use flags instead of environment variables 2026-01-22 09:42:22 +01:00
Pascal Bleser
b77bd0b9e3 docs(groupware): more developer instructions 2026-01-22 09:42:22 +01:00
Pascal Bleser
45c6181132 more updates to the Groupware DEVELOPER.md 2026-01-22 09:42:22 +01:00
Pascal Bleser
2ea415bc85 docs(groupware): add configuration instructions to DEVELOPER.md 2026-01-22 09:42:22 +01:00
Pascal Bleser
299a356076 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-01-22 09:42:22 +01:00
Pascal Bleser
9c517a8c91 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-01-22 09:42:22 +01:00
Pascal Bleser
8b0f58534b refactor(groupware): use a function for multi-account method call IDs
* introduce a function 'mcid' to assemble method call IDs per account
   instead of doing that inline in each function, in case the rules for
   doing so change in the future
2026-01-22 09:42:22 +01:00
Pascal Bleser
cb2de144bb docs(groupware): add services/groupware/DEVELOPER.md 2026-01-22 09:42:22 +01:00
Pascal Bleser
b0768ae4b5 refactor(groupware): add max requests check
* move jmap.request() to jmap.Client.request() and pass the Session
   and a Logger to introduce checking the number of methodCalls within a
   request not exceeding the limit of the Session, as well as error
   handling and logging there instead of in each caller

 * a few bugfixes:
   - add a few missing Send() calls in logs
   - correct the response tag matching for
     GetMailboxChangesForMultipleAccounts
   - fix typo in Identity.ReplyTo json serialization rune
   - fix response tag in pkg/jmap/testdata/mailboxes1.json after
     changing them to be prefixed by the accountId
2026-01-22 09:42:22 +01:00
Pascal Bleser
a7563532a1 groupware: minor typo fixes 2026-01-22 09:42:22 +01:00
Pascal Bleser
80ec0c9236 chore(groupware): add launcher for OC + containers for services
* add a launcher for running OpenCloud from within VSCode, but using
   third-party services that are running within the docker compose
   'full' example setup
2026-01-22 09:42:22 +01:00
Pascal Bleser
c336b4ced7 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-01-22 09:42:22 +01:00
Pascal Bleser
0cce8f5df3 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-01-22 09:42:22 +01:00
Pascal Bleser
9680008790 test(groupware): add testcontainers based jmap test
* adds pkg/jmap/jmap_integration_test.go

 * uses ghcr.io/stalwartlabs/stalwart:v0.13.2-alpine

 * can be disabled by setting one of the following environment
   variables, in the same fashion as ca0493b28
   - CI=woodpecker
   - CI_SYSTEM_NAME=woodpecker
   - USE_TESTCONTAINERS=false

 * dependencies:
   - bump github.com/go-test/deep from 1.1.0 to 1.1.1
   - add github.com/cention-sany/utf7
   - add github.com/dustinkirkland/golang-petname
   - add github.com/emersion/go-imap/v2
   - add github.com/emersion/go-message
   - add github.com/emersion/go-sasl
   - add github.com/go-crypt/crypt
   - add github.com/go-crypt/x
   - add github.com/gogs/chardet
   - add github.com/inbucket/html2text
   - add github.com/jhilleryerd/enmime/v2
   - add github.com/ssor/bom
   - add gopkg.in/loremipsum.v1
2026-01-22 09:42:19 +01:00
Pascal Bleser
17620483b2 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-01-22 09:39:16 +01:00
Pascal Bleser
16c9b7eaf0 groupware: add DNS auto-discovery (currently disabled, needs testing) 2026-01-22 09:39:16 +01:00
Pascal Bleser
058c299ccb add a .gitignore entry for debug binaries built by VSCode when running OpenCloud 2026-01-22 09:39:16 +01:00
Pascal Bleser
668db6598d 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-01-22 09:39:16 +01:00
Pascal Bleser
6c7cfac90c groupware: fix debug server, was missing a lot of configuration options and was binding to :80 2026-01-22 09:39:16 +01:00
Pascal Bleser
f2be11dcab docs(groupware): add Groupware related ADRs 2026-01-22 09:39:16 +01:00
Pascal Bleser
837dd3a660 refactor(groupware): logging and metrics improvements
* some minor code refactorings to improve logging and metrics

 * more code documentation
2026-01-22 09:39:16 +01:00
Pascal Bleser
0c1fd1e341 jmap: minor logging improvements 2026-01-22 09:39:16 +01:00
Pascal Bleser
15c50b3bf4 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-01-22 09:39:16 +01:00
Pascal Bleser
6af523c290 groupware: jmap: add metrics 2026-01-22 09:39:16 +01:00
Pascal Bleser
306e5a0dce groupware: implement metrics
* implement a framework for metrics, with a few exemplary ones
2026-01-22 09:39:16 +01:00
Pascal Bleser
d5f75ad8e0 groupware: Etag handling
* implement correct Etag and If-None-Match handling, responding with
   304 Not Modified if they match

 * introduce SessionState and State string type aliases to ensure we are
   using the correct fields for those, respectively

 * extract the SessionState from the JMAP response bodies in the
   groupware framework instead of having to do that in every single
   groupware API

 * use uint instead of int in some places to clarify that the values are
   >= 0

 * trace-log how long a Session was held in cache before being evicted

 * add Trace-Id header handling: add to response when specified in
   request, and implement a custom request logger to include it as a
   field

 * implement a more compact trace-logging of all the methods and URIs
   that are served, to put them into a single log entry instead of
   creating one log entry for every URI
2026-01-22 09:39:16 +01:00
Pascal Bleser
eab949ba68 groupware: initial related emails implementation with SSE 2026-01-22 09:39:16 +01:00