69c8968cb0 
								
							 
						 
						
							
							
								
								Add byte-array-based methods to FaultTolerantRedisCluster.  
							
							
							
						 
						
							2020-07-30 11:39:14 -04:00  
				
					
						
							
							
								 
						
							
								7f8f2641f6 
								
							 
						 
						
							
							
								
								Simplify registration lock counting by avoiding inactive accounts.  
							
							
							
						 
						
							2020-07-28 11:48:20 -04:00  
				
					
						
							
							
								 
						
							
								022dbb606f 
								
							 
						 
						
							
							
								
								Count registration lock versions when crawling the account database.  
							
							
							
						 
						
							2020-07-28 11:48:20 -04:00  
				
					
						
							
							
								 
						
							
								eea073f882 
								
							 
						 
						
							
							
								
								Decommission the old cache.  
							
							
							
						 
						
							2020-07-28 10:29:28 -04:00  
				
					
						
							
							
								 
						
							
								fc1d88f5bb 
								
							 
						 
						
							
							
								
								Read exclusively from the cache cluster.  
							
							
							
						 
						
							2020-07-27 15:11:40 -04:00  
				
					
						
							
							
								 
						
							
								89bafea61f 
								
							 
						 
						
							
							
								
								Move SMS strings to configuration  
							
							
							
						 
						
							2020-07-27 11:23:21 -05:00  
				
					
						
							
							
								 
						
							
								0fbf31ec98 
								
							 
						 
						
							
							
								
								Clear each cluster node individually.  
							
							
							
						 
						
							2020-07-22 11:12:21 -04:00  
				
					
						
							
							
								 
						
							
								db9b7ca447 
								
							 
						 
						
							
							
								
								Fix slot assignment when building a cluster for tests.  
							
							
							
						 
						
							2020-07-22 11:04:10 -04:00  
				
					
						
							
							
								 
						
							
								eecc71c77f 
								
							 
						 
						
							
							
								
								Revert batch message storage. ( #95 )  
							
							
							
						 
						
							2020-07-20 16:28:32 -04:00  
				
					
						
							
							
								 
						
							
								215125de26 
								
							 
						 
						
							
							
								
								Update tests.  
							
							
							
						 
						
							2020-07-20 10:30:29 -04:00  
				
					
						
							
							
								 
						
							
								247d869a5c 
								
							 
						 
						
							
							
								
								De-randomize message tests to minimize flakiness.  
							
							
							
						 
						
							2020-07-14 18:46:39 -04:00  
				
					
						
							
							
								 
						
							
								b7e0e5a356 
								
							 
						 
						
							
							
								
								Create a strategy class to decide which sender id to use  
							
							... 
							
							
							
							The rules around selecting sender ids can get complicated with some
countries not supporting it and others requiring pre-registration that
may result in having a different sender id for that country than
others. This strategy class handles the logic of dealing with this
expanded configuration and applying the appropriate sender id or none
when it's not appropriate to do so at all. 
							
						 
						
							2020-07-14 10:53:48 -05:00  
				
					
						
							
							
								 
						
							
								c5d0d4acd0 
								
							 
						 
						
							
							
								
								Revert "Move rate limiter logic to Lua scripts"  
							
							... 
							
							
							
							This reverts commit b585c6676d 
							
						 
						
							2020-07-09 12:30:25 -04:00  
				
					
						
							
							
								 
						
							
								dcb11f7606 
								
							 
						 
						
							
							
								
								Log errors from experiments.  
							
							
							
						 
						
							2020-07-07 15:17:25 -04:00  
				
					
						
							
							
								 
						
							
								933ce42d5a 
								
							 
						 
						
							
							
								
								Test rate limiters against a real cluster.  
							
							
							
						 
						
							2020-07-07 15:17:25 -04:00  
				
					
						
							
							
								 
						
							
								e021286eee 
								
							 
						 
						
							
							
								
								Add configuration by country for sending from alpha IDs  
							
							
							
						 
						
							2020-07-07 10:17:40 -05:00  
				
					
						
							
							
								 
						
							
								0ee7a66033 
								
							 
						 
						
							
							
								
								Keep trying ports until you get one lower than 55535 ( #83 )  
							
							... 
							
							
							
							* Keep trying ports until you get one lower than 55535
* Rename method and change to do...while
* Limit attempts to 11,000 to find an open redis cluster port 
							
						 
						
							2020-07-07 10:12:31 -05:00  
				
					
						
							
							
								 
						
							
								42c797ee97 
								
							 
						 
						
							
							
								
								Set the default log level for tests to WARN.  
							
							
							
						 
						
							2020-07-07 11:05:39 -04:00  
				
					
						
							
							
								 
						
							
								b585c6676d 
								
							 
						 
						
							
							
								
								Move rate limiter logic to Lua scripts  
							
							
							
						 
						
							2020-07-06 10:10:13 -04:00  
				
					
						
							
							
								 
						
							
								f5ddb0f1f8 
								
							 
						 
						
							
							
								
								Test ClusterLuaScript against a real Redis cluster.  
							
							
							
						 
						
							2020-07-02 18:58:30 -04:00  
				
					
						
							
							
								 
						
							
								25a5a8db68 
								
							 
						 
						
							
							
								
								Set avatar to null on Account when request is false ( #78 )  
							
							
							
						 
						
							2020-06-29 15:53:31 -05:00  
				
					
						
							
							
								 
						
							
								a68d91b54c 
								
							 
						 
						
							
							
								
								Resolve some test flakiness by adding a deterministic "wait" mechanism. (SERVER-86)  
							
							
							
						 
						
							2020-06-29 12:24:25 -04:00  
				
					
						
							
							
								 
						
							
								bbf5e1fa78 
								
							 
						 
						
							
							
								
								Use the UA string from websocket upgrade requests if available.  
							
							
							
						 
						
							2020-06-17 15:40:18 -04:00  
				
					
						
							
							
								 
						
							
								6adcebb247 
								
							 
						 
						
							
							
								
								Return to just using counters instead of timers for measuring experiment outcomes.  
							
							
							
						 
						
							2020-06-17 15:34:02 -04:00  
				
					
						
							
							
								 
						
							
								a0bebca1e6 
								
							 
						 
						
							
							
								
								Extend Experiment to report more detail when results don't match.  
							
							
							
						 
						
							2020-06-16 16:46:41 -04:00  
				
					
						
							
							
								 
						
							
								c17cc07b73 
								
							 
						 
						
							
							
								
								Instrument BlockingThreadPoolExecutor.  
							
							
							
						 
						
							2020-06-12 14:43:50 -04:00  
				
					
						
							
							
								 
						
							
								9afc433db4 
								
							 
						 
						
							
							
								
								Record exceptions associated with server responses.  
							
							
							
						 
						
							2020-06-11 22:08:07 -04:00  
				
					
						
							
							
								 
						
							
								f701e3d834 
								
							 
						 
						
							
							
								
								Record distributions of timer values; stop recording error causes.  
							
							
							
						 
						
							2020-06-11 11:50:36 -04:00  
				
					
						
							
							
								 
						
							
								0671f05c05 
								
							 
						 
						
							
							
								
								Introduce experiment comparison methods for suppliers.  
							
							
							
						 
						
							2020-06-11 11:50:36 -04:00  
				
					
						
							
							
								 
						
							
								0713da7393 
								
							 
						 
						
							
							
								
								Record experiment results with a timer instead of a counter.  
							
							
							
						 
						
							2020-06-11 11:50:36 -04:00  
				
					
						
							
							
								 
						
							
								28c765bd9a 
								
							 
						 
						
							
							
								
								Add an in-app-context test for websocket metrics.  
							
							
							
						 
						
							2020-06-09 15:45:32 -04:00  
				
					
						
							
							
								 
						
							
								ec858b2d4c 
								
							 
						 
						
							
							
								
								Set a timeout for Redis cluster operations and shut down the cluster as part of service shutdown  
							
							
							
						 
						
							2020-06-07 18:27:57 -04:00  
				
					
						
							
							
								 
						
							
								52310b5dd9 
								
							 
						 
						
							
							
								
								Compare results of reads from old and new Redis caches.  
							
							
							
						 
						
							2020-06-07 18:27:11 -04:00  
				
					
						
							
							
								 
						
							
								c2a4a2778e 
								
							 
						 
						
							
							
								
								Introduce the Experiment class to compare results from parallel systems.  
							
							
							
						 
						
							2020-06-07 18:27:11 -04:00  
				
					
						
							
							
								 
						
							
								1388103919 
								
							 
						 
						
							
							
								
								Mirror writes to the cache cluster.  
							
							
							
						 
						
							2020-06-06 20:37:48 -04:00  
				
					
						
							
							
								 
						
							
								fe1054d58a 
								
							 
						 
						
							
							
								
								Introduce a Lettuce-based fault-tolerant Redis cluster accessor.  
							
							
							
						 
						
							2020-06-06 20:37:48 -04:00  
				
					
						
							
							
								 
						
							
								ba6ac778fc 
								
							 
						 
						
							
							
								
								Update to Pushy v0.14.1.  
							
							
							
						 
						
							2020-06-05 12:21:56 -04:00  
				
					
						
							
							
								 
						
							
								228ffcbfce 
								
							 
						 
						
							
							
								
								Differentiate between websocket and "boring" HTTP traffic.  
							
							
							
						 
						
							2020-05-28 12:52:49 -04:00  
				
					
						
							
							
								 
						
							
								06c82ee87d 
								
							 
						 
						
							
							
								
								Celebrate the diversity of UA strings when generating tags for metrics.  
							
							
							
						 
						
							2020-05-27 19:35:42 -04:00  
				
					
						
							
							
								 
						
							
								9ba5ee8043 
								
							 
						 
						
							
							
								
								Move UA tag extraction into its own utility class.  
							
							
							
						 
						
							2020-05-27 19:35:42 -04:00  
				
					
						
							
							
								 
						
							
								eede4e50ca 
								
							 
						 
						
							
							
								
								Use hashed UUID to spread last seen updates over a full day ( #40 )  
							
							
							
						 
						
							2020-05-26 13:38:52 -07:00  
				
					
						
							
							
								 
						
							
								aa10f63d9f 
								
							 
						 
						
							
							
								
								Add the timestamp using the `add` method.  
							
							
							
						 
						
							2020-05-22 17:39:25 -04:00  
				
					
						
							
							
								 
						
							
								a13c44d81a 
								
							 
						 
						
							
							
								
								Capture request-level metrics (path, status, client platform/version).  
							
							
							
						 
						
							2020-05-20 17:48:19 -04:00  
				
					
						
							
							
								 
						
							
								7da9e88c0b 
								
							 
						 
						
							
							
								
								Add hashKey to RemoteConfig  
							
							... 
							
							
							
							This allows the percentages for different entries in remote config to
be aligned so one remote config can be a subset of another. 
							
						 
						
							2020-05-13 11:08:22 -07:00  
				
					
						
							
							
								 
						
							
								1c73c91133 
								
							 
						 
						
							
							
								
								Report the number of days until the CDS CA cert expires as a metric so we can set an alarm.  
							
							
							
						 
						
							2020-05-12 12:57:11 -04:00  
				
					
						
							
							
								 
						
							
								001a9310c3 
								
							 
						 
						
							
							
								
								Support device transfers (SERVER-41, SERVER-42) ( #32 )  
							
							... 
							
							
							
							This change introduces a `transfer` device capability and account creation argument in support of the iOS device transfer effort. 
							
						 
						
							2020-05-12 12:23:18 -04:00  
				
					
						
							
							
								 
						
							
								acfbab5915 
								
							 
						 
						
							
							
								
								Update to Pushy v0.13.11.  
							
							
							
						 
						
							2020-05-04 17:50:35 -04:00  
				
					
						
							
							
								 
						
							
								48c324fe86 
								
							 
						 
						
							
							
								
								Use a static sequence of randomness in tests  
							
							... 
							
							
							
							The RemoteConfigControllerTest#testMath unit test would occassionally
fail because randomness doesn't necessarily group into expected ranges
over a finite trial count. This changes the test to use a predefined
PRNG sequence instead of one that varies with each test so that the
test will no long randomly fail. 
							
						 
						
							2020-04-29 17:31:43 -07:00  
				
					
						
							
							
								 
						
							
								0c495e7e72 
								
							 
						 
						
							
							
								
								Workaround lack of internal retry on transaction rollback  
							
							... 
							
							
							
							The get endpoint for key fetching can fail if the transaction cannot
complete because of simultaneous modification. Clients currently
receive 500 from this and retry if it happens, but this test case runs
into it without retrying and then complains that not all the threads
completed successfully. This workaround adds some retry attempts. 
							
						 
						
							2020-04-29 17:10:13 -07:00  
				
					
						
							
							
								 
						
							
								50ccfee201 
								
							 
						 
						
							
							
								
								Allow remote config to send non-boolean values  
							
							... 
							
							
							
							This version of remote config allows non-boolean values to be returned
to clients but unfortunately limits the configuration to only one
value or another. There is no way to configure more than two values
for the same key with this setup. 
							
						 
						
							2020-04-29 10:51:10 -07:00  
				
					
						
							
							
								 
						
							
								95f0ce1816 
								
							 
						 
						
							
							
								
								Support for advertising payment addresses on profile  
							
							
							
						 
						
							2020-04-22 12:32:53 -07:00  
				
					
						
							
							
								 
						
							
								1408ac77f9 
								
							 
						 
						
							
							
								
								Make storageCapable a boolean result rather than an auth token  
							
							
							
						 
						
							2020-04-09 10:19:49 -07:00  
				
					
						
							
							
								 
						
							
								7e97d10ae1 
								
							 
						 
						
							
							
								
								Fix account dropping new style registration locks  
							
							
							
						 
						
							2020-04-06 09:27:23 -07:00  
				
					
						
							
							
								 
						
							
								41286650cc 
								
							 
						 
						
							
							
								
								Create attachments V3 endpoint for CDN2 on GCP  
							
							... 
							
							
							
							In preparation for resumable uploads, this creates a separate
attachment authorization endpoint that creates a signed URL for
accessing GCP Storage through Signal's CDN2. This should allow Signal
clients to do byte-level resume of media uploads. 
							
						 
						
							2020-04-02 10:20:42 -07:00  
				
					
						
							
							
								 
						
							
								3c8e7c6c10 
								
							 
						 
						
							
							
								
								Add storage capability and return KBS creds on rereg w/ storage set  
							
							
							
						 
						
							2020-03-27 10:45:48 -07:00  
				
					
						
							
							
								 
						
							
								ac1153c7cf 
								
							 
						 
						
							
							
								
								Additional limits  
							
							
							
						 
						
							2020-03-14 18:10:07 -07:00  
				
					
						
							
							
								 
						
							
								3b1672a4a7 
								
							 
						 
						
							
							
								
								Update zkgroups to 0.4.0  
							
							
							
						 
						
							2020-03-14 16:30:13 -07:00  
				
					
						
							
							
								 
						
							
								e5746c19cf 
								
							 
						 
						
							
							
								
								Support for GV2 capability flag  
							
							
							
						 
						
							2020-02-07 11:53:28 -08:00  
				
					
						
							
							
								 
						
							
								e399f9e851 
								
							 
						 
						
							
							
								
								Generate external creds for KBS based on UUID  
							
							
							
						 
						
							2020-01-22 13:47:33 -08:00  
				
					
						
							
							
								 
						
							
								e4e20c2d25 
								
							 
						 
						
							
							
								
								Add support for UUID buckets in remote config  
							
							
							
						 
						
							2020-01-22 11:28:08 -08:00  
				
					
						
							
							
								 
						
							
								08a70664f4 
								
							 
						 
						
							
							
								
								Support for getting/setting remote config variables  
							
							
							
						 
						
							2020-01-21 13:38:58 -08:00  
				
					
						
							
							
								 
						
							
								75fc35ee4b 
								
							 
						 
						
							
							
								
								Parameterize access to zk operations  
							
							
							
						 
						
							2020-01-21 11:29:08 -08:00  
				
					
						
							
							
								 
						
							
								ba3102d667 
								
							 
						 
						
							
							
								
								Support for versioned profiles  
							
							... 
							
							
							
							Includes support for issuing zkgroup auth credentials 
							
						 
						
							2020-01-21 11:04:06 -08:00  
				
					
						
							
							
								 
						
							
								8a9fed64f2 
								
							 
						 
						
							
							
								
								Support for first/last profile name length  
							
							
							
						 
						
							2020-01-13 18:55:04 -08:00  
				
					
						
							
							
								 
						
							
								71c7e30548 
								
							 
						 
						
							
							
								
								Increase max size for sticker manifest  
							
							
							
						 
						
							2019-12-19 10:29:47 -08:00  
				
					
						
							
							
								 
						
							
								886db1a2c3 
								
							 
						 
						
							
							
								
								Bump max sticker count to 201  
							
							
							
						 
						
							2019-12-18 17:08:51 -08:00  
				
					
						
							
							
								 
						
							
								b4c06db031 
								
							 
						 
						
							
							
								
								Make redis failures on write-back retrieve non-fatal  
							
							
							
						 
						
							2019-11-20 12:36:22 -08:00  
				
					
						
							
							
								 
						
							
								2b987e6e93 
								
							 
						 
						
							
							
								
								Usernames can't start with numbers  
							
							
							
						 
						
							2019-11-20 12:36:22 -08:00  
				
					
						
							
							
								 
						
							
								523134f24b 
								
							 
						 
						
							
							
								
								Username reservation table  
							
							
							
						 
						
							2019-11-20 12:36:22 -08:00  
				
					
						
							
							
								 
						
							
								99c228dd6d 
								
							 
						 
						
							
							
								
								Support for setting and looking up usernames  
							
							
							
						 
						
							2019-11-20 12:36:22 -08:00  
				
					
						
							
							
								 
						
							
								c623f70caa 
								
							 
						 
						
							
							
								
								Add support for capabilities  
							
							
							
						 
						
							2019-11-14 13:36:40 -08:00  
				
					
						
							
							
								 
						
							
								f16b783378 
								
							 
						 
						
							
							
								
								return backup, not storage, credentials for reg lock  
							
							
							
						 
						
							2019-11-05 10:36:33 -08:00  
				
					
						
							
							
								 
						
							
								be4b75932b 
								
							 
						 
						
							
							
								
								since onCrawlChunk() is now protected, we need to invoke timeAndProcessChunk() in our unit tests  
							
							
							
						 
						
							2019-10-29 18:20:03 -07:00  
				
					
						
							
							
								 
						
							
								eddfacd0f4 
								
							 
						 
						
							
							
								
								add timers to the account crawler listeners  
							
							
							
						 
						
							2019-10-25 21:30:48 -07:00  
				
					
						
							
							
								 
						
							
								69742839c0 
								
							 
						 
						
							
							
								
								uuid-based account crawler  
							
							
							
						 
						
							2019-08-27 14:42:14 -07:00  
				
					
						
							
							
								 
						
							
								20b5f0e681 
								
							 
						 
						
							
							
								
								Reset cache index  
							
							
							
						 
						
							2019-08-27 14:08:50 -07:00  
				
					
						
							
							
								 
						
							
								3803b8f284 
								
							 
						 
						
							
							
								
								Fix for jedis pool deadlock  
							
							... 
							
							
							
							1) Remove nested pool checkouts
2) Add a max wait so it won't block forever on deadlock 
							
						 
						
							2019-08-27 14:02:42 -07:00  
				
					
						
							
							
								 
						
							
								cf78047830 
								
							 
						 
						
							
							
								
								revert to phone number-based account crawler  
							
							
							
						 
						
							2019-08-26 14:00:15 -07:00  
				
					
						
							
							
								 
						
							
								79f2efdfd9 
								
							 
						 
						
							
							
								
								Make UUID in sealed sender certificate optional for buggy clients  
							
							
							
						 
						
							2019-08-26 11:09:54 -07:00  
				
					
						
							
							
								 
						
							
								07822b371f 
								
							 
						 
						
							
							
								
								replicate uuids to contact discovery  
							
							
							
						 
						
							2019-08-26 11:09:54 -07:00  
				
					
						
							
							
								 
						
							
								7a3a385569 
								
							 
						 
						
							
							
								
								Support for UUID based addressing  
							
							
							
						 
						
							2019-08-26 11:09:54 -07:00  
				
					
						
							
							
								 
						
							
								10724fee04 
								
							 
						 
						
							
							
								
								Support for sticker pack uploads  
							
							
							
						 
						
							2019-07-24 16:29:56 -07:00  
				
					
						
							
							
								 
						
							
								11902dec3c 
								
							 
						 
						
							
							
								
								Support for v2 registration lock  
							
							
							
						 
						
							2019-07-11 18:15:14 -07:00  
				
					
						
							
							
								 
						
							
								4fdbe9b9ff 
								
							 
						 
						
							
							
								
								Support for push preauth  
							
							
							
						 
						
							2019-07-11 18:15:10 -07:00  
				
					
						
							
							
								 
						
							
								a6e7e30177 
								
							 
						 
						
							
							
								
								Add requester to recaptcha validation  
							
							
							
						 
						
							2019-07-11 17:31:34 -07:00  
				
					
						
							
							
								 
						
							
								5b69ff7e94 
								
							 
						 
						
							
							
								
								Break out keys database and accounts database  
							
							
							
						 
						
							2019-06-19 17:16:37 -07:00  
				
					
						
							
							
								 
						
							
								bc0c6be4c5 
								
							 
						 
						
							
							
								
								We don't need to support disabled accounts for the signed PK API  
							
							
							
						 
						
							2019-06-12 12:32:15 -07:00  
				
					
						
							
							
								 
						
							
								105a38a7db 
								
							 
						 
						
							
							
								
								Update gcm-sender-async to use jdk11 httpclient  
							
							
							
						 
						
							2019-05-30 10:46:40 -07:00  
				
					
						
							
							
								 
						
							
								a029768d24 
								
							 
						 
						
							
							
								
								Reenable account cleaner  
							
							
							
						 
						
							2019-05-10 10:42:42 -07:00  
				
					
						
							
							
								 
						
							
								4d9c9206cf 
								
							 
						 
						
							
							
								
								Delay processing FCM uninstalled feedback  
							
							... 
							
							
							
							Check to make sure client is not still active before unregistering,
since FCM feedback seems to be often erroneous 
							
						 
						
							2019-05-07 10:04:22 -07:00  
				
					
						
							
							
								 
						
							
								35116f9229 
								
							 
						 
						
							
							
								
								Clean up concepts of enabled account state  
							
							... 
							
							
							
							1) Rename "active" methods to be "enabled," since they aren't
   really about "activity."
2) Make authentication fail if a device or account is in dissabled
   state.
3) Let some controllers authenticate accounts that are in a
   disabled state. 
							
						 
						
							2019-05-04 12:31:50 -07:00  
				
					
						
							
							
								 
						
							
								a1f90cd39b 
								
							 
						 
						
							
							
								
								Temporarily disable account cleaner  
							
							
							
						 
						
							2019-05-03 12:09:01 -07:00  
				
					
						
							
							
								 
						
							
								45dc7459b8 
								
							 
						 
						
							
							
								
								Temporarily disable GCM unregistered feedback  
							
							
							
						 
						
							2019-05-03 11:51:21 -07:00  
				
					
						
							
							
								 
						
							
								6877b663f1 
								
							 
						 
						
							
							
								
								enable up to 40 account updates per chunk in AccountCleaner  
							
							
							
						 
						
							2019-05-03 10:58:57 -07:00  
				
					
						
							
							
								 
						
							
								3c69f81a10 
								
							 
						 
						
							
							
								
								expire accounts explicitly  
							
							
							
						 
						
							2019-05-02 21:14:57 -07:00  
				
					
						
							
							
								 
						
							
								d316d57e5d 
								
							 
						 
						
							
							
								
								fix DirectoryController tests  
							
							
							
						 
						
							2019-05-02 19:20:23 -07:00  
				
					
						
							
							
								 
						
							
								0c81556b90 
								
							 
						 
						
							
							
								
								Switch websocket-resources from ListenableFuture to CompletableFuture  
							
							
							
						 
						
							2019-05-02 15:05:44 -07:00  
				
					
						
							
							
								 
						
							
								d0d375aeb7 
								
							 
						 
						
							
							
								
								Break out into a multi-module project  
							
							
							
						 
						
							2019-05-01 13:19:11 -07:00