mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-25 22:32:03 +02:00 
			
		
		
		
	Merge pull request #2301 from xwiki-labs/push-redact-content
Add configuration parameter to allow redaction of content from push m…
This commit is contained in:
		
						commit
						ff13c5e7af
					
				| @ -33,6 +33,7 @@ from .jwt import JWTConfig | ||||
| from .password_auth_providers import PasswordAuthProviderConfig | ||||
| from .emailconfig import EmailConfig | ||||
| from .workers import WorkerConfig | ||||
| from .push import PushConfig | ||||
| 
 | ||||
| 
 | ||||
| class HomeServerConfig(TlsConfig, ServerConfig, DatabaseConfig, LoggingConfig, | ||||
| @ -40,7 +41,7 @@ class HomeServerConfig(TlsConfig, ServerConfig, DatabaseConfig, LoggingConfig, | ||||
|                        VoipConfig, RegistrationConfig, MetricsConfig, ApiConfig, | ||||
|                        AppServiceConfig, KeyConfig, SAML2Config, CasConfig, | ||||
|                        JWTConfig, PasswordConfig, EmailConfig, | ||||
|                        WorkerConfig, PasswordAuthProviderConfig,): | ||||
|                        WorkerConfig, PasswordAuthProviderConfig, PushConfig,): | ||||
|     pass | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										45
									
								
								synapse/config/push.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								synapse/config/push.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
| # Copyright 2015, 2016 OpenMarket Ltd | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| 
 | ||||
| from ._base import Config | ||||
| 
 | ||||
| 
 | ||||
| class PushConfig(Config): | ||||
|     def read_config(self, config): | ||||
|         self.push_redact_content = False | ||||
| 
 | ||||
|         push_config = config.get("email", {}) | ||||
|         self.push_redact_content = push_config.get("redact_content", False) | ||||
| 
 | ||||
|     def default_config(self, config_dir_path, server_name, **kwargs): | ||||
|         return """ | ||||
|         # Control how push messages are sent to google/apple to notifications. | ||||
|         # Normally every message said in a room with one or more people using | ||||
|         # mobile devices will be posted to a push server hosted by matrix.org | ||||
|         # which is registered with google and apple in order to allow push | ||||
|         # notifications to be sent to these mobile devices. | ||||
|         # | ||||
|         # Setting redact_content to true will make the push messages contain no | ||||
|         # message content which will provide increased privacy. This is a | ||||
|         # temporary solution pending improvements to Android and iPhone apps | ||||
|         # to get content from the app rather than the notification. | ||||
|         # | ||||
|         # For modern android devices the notification content will still appear | ||||
|         # because it is loaded by the app. iPhone, however will send a | ||||
|         # notification saying only that a message arrived and who it came from. | ||||
|         # | ||||
|         #push: | ||||
|         #   redact_content: false | ||||
|         """ | ||||
| @ -275,7 +275,7 @@ class HttpPusher(object): | ||||
|         if event.type == 'm.room.member': | ||||
|             d['notification']['membership'] = event.content['membership'] | ||||
|             d['notification']['user_is_target'] = event.state_key == self.user_id | ||||
|         if 'content' in event: | ||||
|         if not self.hs.config.push_redact_content and 'content' in event: | ||||
|             d['notification']['content'] = event.content | ||||
| 
 | ||||
|         # We no longer send aliases separately, instead, we send the human | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user