Skip to content

Commit

Permalink
Merge develop into mls
Browse files Browse the repository at this point in the history
  • Loading branch information
pcapriotti committed Sep 27, 2023
2 parents a70c099 + eee936e commit 9317e55
Show file tree
Hide file tree
Showing 102 changed files with 1,452 additions and 710 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Wire™

[![Wire logo](https://github.com/wireapp/wire/blob/master/assets/header-small.png?raw=true)](https://start.wire.com/careers-en)
[![Wire logo](https://github.com/wireapp/wire/blob/master/assets/header-small.png?raw=true)](https://wire.bamboohr.com/careers)

This repository is part of the source code of Wire. You can find more information at [wire.com](https://wire.com) or by contacting opensource@wire.com.

Expand Down
2 changes: 2 additions & 0 deletions cabal.project
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,8 @@ package hscim
ghc-options: -Werror
package http2-manager
ghc-options: -Werror
package integration
ghc-options: -Werror
package imports
ghc-options: -Werror
package jwt-tools
Expand Down
1 change: 1 addition & 0 deletions changelog.d/3-bug-fixes/WPB-4787
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Create a new http2 connection in every federator client request instead of using a shared connection.
1 change: 1 addition & 0 deletions changelog.d/3-bug-fixes/WPB-4835
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
list-clients returns with partial success even if one of the remote backends is unreachable
1 change: 1 addition & 0 deletions changelog.d/4-docs/WPB-4556-internal-user-creation
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Elaborate on internal user creation in prod
2 changes: 1 addition & 1 deletion changelog.d/5-internal/WPB-4406
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
- Extending the information returned in errors for Federator. Paths and response bodies, if available, are included in error logs.
- Prometheus metrics for outgoing and incoming federation requests added.
- Prometheus metrics for outgoing and incoming federation requests added. They can be enabled by setting `metrics.serviceMonitor.enabled`, like in other charts.
1 change: 1 addition & 0 deletions changelog.d/5-internal/background-worker-nosync
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
background-worker: Get list of domains from RabbitMQ instead of brig for pushing backend notifications
1 change: 1 addition & 0 deletions changelog.d/5-internal/shutdown-cleanup
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Avoid unnecessary error logs on service shutdown
9 changes: 9 additions & 0 deletions changelog.d/5-internal/xml-reports
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
All integration tests can generate XML reports.

To generate the report in brig-integration, galley-integration,
cargohold-integration, gundeck-integration, stern-integration and the new
integration suite pass `--xml=<outfile>` to generate the XML file.

For spar-integration and federator-integration pass `-f junit` and set
`JUNIT_OUTPUT_DIRECTORY` and `JUNIT_SUITE_NAME` environment variables. The XML
report will be generated at `$JUNIT_OUTPUT_DIRECTORY/junit.xml`.
3 changes: 3 additions & 0 deletions changelog.d/6-federation/tcp-timeout
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
federator: Allow setting TCP connection timeout for HTTP2 requests

The helm chart defaults it to 5s which should be best for most installations.
8 changes: 0 additions & 8 deletions charts/background-worker/templates/configmap.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,6 @@ data:
host: federator
port: 8080
galley:
host: galley
port: 8080
brig:
host: brig
port: 8080
rabbitmq:
{{toYaml .rabbitmq | indent 6 }}
backendNotificationPusher:
Expand Down
1 change: 1 addition & 0 deletions charts/background-worker/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ config:
backendNotificationPusher:
pushBackoffMinWait: 10000 # in microseconds, so 10ms
pushBackoffMaxWait: 300000000 # microseconds, so 300s
remotesRefreshInterval: 300000000 # microseconds, so 300s

serviceAccount:
# When setting this to 'false', either make sure that a service account named
Expand Down
1 change: 1 addition & 0 deletions charts/federator/templates/configmap.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -51,5 +51,6 @@ data:
clientCertificate: "/etc/wire/federator/secrets/tls.crt"
clientPrivateKey: "/etc/wire/federator/secrets/tls.key"
useSystemCAStore: {{ .useSystemCAStore }}
tcpConnectionTimeout: {{ .tcpConnectionTimeout }}
{{- end }}
{{- end }}
19 changes: 19 additions & 0 deletions charts/federator/templates/servicemonitor.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
{{- if .Values.metrics.serviceMonitor.enabled }}
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
name: federator
labels:
app: federator
chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
spec:
endpoints:
- port: internal
path: /i/metrics
selector:
matchLabels:
app: federator
release: {{ .Release.Name }}
{{- end }}
6 changes: 6 additions & 0 deletions charts/federator/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ service:
internalFederatorPort: 8080
externalFederatorPort: 8081

metrics:
serviceMonitor:
enabled: false

tls:
# if enabled, federator will get its client certificate and private key from
# the secret used by the federator ingress
Expand Down Expand Up @@ -41,6 +45,8 @@ config:
# A client certificate and corresponding private key can be specified
# similarly to a custom CA store.
useSystemCAStore: true
# In microseconds, default is 5s.
tcpConnectionTimeout: 5000000

podSecurityContext:
allowPrivilegeEscalation: false
Expand Down
4 changes: 4 additions & 0 deletions charts/outlook-addin/Chart.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
apiVersion: v1
name: outlook-addin
version: 4.38.0
description: Helm chart for outlook addin for Wire
191 changes: 191 additions & 0 deletions charts/outlook-addin/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,191 @@
# How to install Outlook AddIn for Wire-Server

WIP: Some of these configurations are subject to change down the line. This documentation will be updated accordingly as they happen.

This document assumes you already have an instance of wire-server running. If you don't, follow this [documentation](https://github.com/wireapp/wire-server-deploy/blob/master/offline/docs.md)

## Set up OAuth with wire-server

To use OAuth, first you will need to enable it by editing `values/wire-server/values.yaml` as follows:

```
brig:
# ...
config:
# ...
optSettings:
# ...
setOAuthEnabled: true
```

Then you will need to generate a key using "OKP" (Octet Key Pair) and the "Ed25519" curve with OpenSSL that will be used as JWK (JSON Web Key) in the wire-server helm chart. This key will be used to sign and verify [OAuth](https://docs.wire.com/developer/reference/oauth.html#setting-up-public-and-private-keys) access tokens.

```
openssl genpkey -algorithm Ed25519 -out private_key.pem
```

You can find a `generate_jwk.py` in this chart which you can use to generate the JWK in JSON format that can be used in your wire-server helm chart. Use it in `brig` and `nginz` namespaces in `values/wire-server/secrets.yaml` like shown below.

```
brig:
secrets:
oauthJwkKeyPair: |
{
"kty": "OKP",
"crv": "Ed25519",
"x": "...",
"d": "...",
"kid": "..."
}
```

```
# values.yaml or secrets.yaml
nginz:
secrets:
oAuth:
publicKeys: |
{
"kty": "OKP",
"crv": "Ed25519",
"x": "...",
"kid": "..."
}
```

Now redeploy wire-server chart:

```
d helm upgrade --install wire-server charts/wire-server --values values/wire-server/values.yaml --values/wire-server/secrets.yaml
```

## Outlook integration feature flag

By default, outlook addin as a feature is disabled for all teams. To change this make the following changes in your configuration in `galley` namespace:

```
galley:
config:
# ...
settings:
# ...
featureFlags:
# ...
outlookCalIntegration:
defaults:
status: enabled
lockStatus: unlocked
```

Redeploy wire-server for these changes to take effect.

NOTE: As of the time of writing `outlookCalIntegration` is not a typo! (at least not in this documentation)

If you have an existing team in your wire-server that did not have this feature flag enabled prior to this. You will need to enable that feature flag through [Backoffice API](https://github.com/wireapp/wire-server/tree/05778a2b14ac5aaffca937d6e2cdd9b7b5f3106d/charts/backoffice).

NOTE: As of the time of writing Backoffice API endpoint for enabling this feature flag is not working as intended so please follow this manual on how to do it with curl on the machine wire-server is running on.

### How to manually enable outlookCalIntegration feature flag for a team

You will need your `teamId` (you can find it in TeamSettings under Customization tab).
List all your pods in your Kubernetes cluster with:

```
d kubectl get pods -owide
```

Copy the name of one of your galley pods and run:

```
d kubectl exec -it galley_pod_name /bin/bash
```

In the new terminal type:

```
curl -v -XPATCH 'http://localhost:8080/i/teams/your_teamID/features/outlookCalIntegration' -H 'content-type: application/json;charset=utf-8' -d '{"status": "enabled", "lockStatus": "unlocked"}'
```

Do this for all the teams you want to enable the feature for.

## Create new client service for OAuth in Brig

List all your pods in your Kubernetes cluster with:

```
d kubectl get pods -owide
```

Copy the name of one of your brig pods and run:

```
d kubectl exec -it brig_pod_name /bin/bash
```

In the new terminal type:

```
curl -s -X POST localhost:8080/i/oauth/clients \
-H "Content-Type: application/json" \
-d '{
"application_name":"Wire Microsoft Outlook Calendar Add-in",
"redirect_url":"https://outlook.example.com/callback.html"
}'
```

You will get back a response in JSON format that should look like:

```
{"client_id":"b2b3...","client_secret":"9ee60..."}
```

Write down your client_id as it will be needed later.

## Deploying Wire Outlook AddIn

Create a new `values.yaml` file in `values/outlook-addin` directory (create the directory too if missing).
Append the following configuration (change the example.com with your domain).

```
host: "outlook.example.com" # this entry has to be without https://!!!
wireApiBaseUrl: "https://nginz-https.example.com"
wireAuthorizationEndpoint: "https://webapp.example.com/auth"
clientId: ""
```

As of the time of writing nginz used by wire-server is not set up to whitelist outlook subdomain for CORS requests. So please edit `charts/wire-server/charts/nginz/values.yaml` and find under `nginx_conf`:

```
allowlisted_origins:
- webapp
- teams
- account
- outlook # add outlook entry so your addin doesnt get CORS blocked
```

### Certificates

If you are using cert-manager just make the following configuration in values.yaml:

```
tls:
issuerRef:
name: letsencrypt-http01 # letsencrypt-http01 is a default config in wire-server, change if needed in your instance
```

Now deploy outlook addin chart with:

```
d helm upgrade --install outlook-addin charts/outlook-addin --values values/outlook-addin/values.yaml
```

If you are using your own provided certificates, deploy the addin with this command:

```
d helm upgrade --install outlook-addin charts/outlook-addin --values values/outlook-addin/values.yaml --set-file tls.crt=/path/to/tls.crt --set-file tls.key=/path/to/tls.key
```

## Install Wire AddIn in Microsoft Outlook

After deploying `outlook-addin` you will be able to find `manifest.xml` file on https://outlook.example.com/manifest.xml which you can use to install the addin in your outlook. You can find instructions and screenshots how to do it [here](https://github.com/tlebon/outlook-addin/blob/staging/README.md#how-to-install-the-add-in-in-ms-outlook).
NOTE: Links in the outlined documents are hardcoded for a testing/prod environment, any reference to zinfra.io or wire.com in it should be treated as example.com.
23 changes: 23 additions & 0 deletions charts/outlook-addin/generate_jwk.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import json
from jwcrypto import jwk
import base64

def pem_to_jwk(pem_key, is_private=True):
key = jwk.JWK.from_pem(pem_key)
if is_private:
key_dict = key.export(as_dict=True, private_key=True)
else:
key_dict = key.export(as_dict=True, private_key=False)
return key_dict

def convert_to_pem(base64_key):
pem_key = base64.b64decode(base64_key)
return pem_key

with open("private_key.pem", "rb") as f:
private_key_pem = f.read()
private_key_b64 = base64.b64encode(private_key_pem).decode('utf-8')
private_jwk = pem_to_jwk(convert_to_pem(private_key_b64), is_private=True)

print("Private JWK:")
print(json.dumps(private_jwk, indent=2))
Loading

0 comments on commit 9317e55

Please sign in to comment.