Updating to latest ycmd
This required changing the HMAC calculation logic.
This commit is contained in:
parent
8e30a02d4f
commit
a70bf21d29
@ -24,8 +24,8 @@ from retries import retries
|
|||||||
from requests_futures.sessions import FuturesSession
|
from requests_futures.sessions import FuturesSession
|
||||||
from ycm.unsafe_thread_pool_executor import UnsafeThreadPoolExecutor
|
from ycm.unsafe_thread_pool_executor import UnsafeThreadPoolExecutor
|
||||||
from ycm import vimsupport
|
from ycm import vimsupport
|
||||||
from ycmd import utils
|
|
||||||
from ycmd.utils import ToUtf8Json
|
from ycmd.utils import ToUtf8Json
|
||||||
|
from ycmd.hmac_utils import CreateRequestHmac, CreateHmac, SecureStringsEqual
|
||||||
from ycmd.responses import ServerError, UnknownExtraConf
|
from ycmd.responses import ServerError, UnknownExtraConf
|
||||||
|
|
||||||
_HEADERS = {'content-type': 'application/json'}
|
_HEADERS = {'content-type': 'application/json'}
|
||||||
@ -89,29 +89,37 @@ class BaseRequest( object ):
|
|||||||
method,
|
method,
|
||||||
timeout = _DEFAULT_TIMEOUT_SEC ):
|
timeout = _DEFAULT_TIMEOUT_SEC ):
|
||||||
def SendRequest( data, handler, method, timeout ):
|
def SendRequest( data, handler, method, timeout ):
|
||||||
|
request_uri = _BuildUri( handler )
|
||||||
if method == 'POST':
|
if method == 'POST':
|
||||||
sent_data = ToUtf8Json( data )
|
sent_data = ToUtf8Json( data )
|
||||||
return BaseRequest.session.post(
|
return BaseRequest.session.post(
|
||||||
_BuildUri( handler ),
|
request_uri,
|
||||||
data = sent_data,
|
data = sent_data,
|
||||||
headers = BaseRequest._ExtraHeaders( sent_data ),
|
headers = BaseRequest._ExtraHeaders( method,
|
||||||
|
request_uri,
|
||||||
|
sent_data ),
|
||||||
timeout = timeout )
|
timeout = timeout )
|
||||||
if method == 'GET':
|
if method == 'GET':
|
||||||
return BaseRequest.session.get(
|
return BaseRequest.session.get(
|
||||||
_BuildUri( handler ),
|
request_uri,
|
||||||
headers = BaseRequest._ExtraHeaders(),
|
headers = BaseRequest._ExtraHeaders( method, request_uri ),
|
||||||
timeout = timeout )
|
timeout = timeout )
|
||||||
|
|
||||||
@retries( 5, delay = 0.5, backoff = 1.5 )
|
@retries( 5, delay = 0.5, backoff = 1.5 )
|
||||||
def DelayedSendRequest( data, handler, method ):
|
def DelayedSendRequest( data, handler, method ):
|
||||||
|
request_uri = _BuildUri( handler )
|
||||||
if method == 'POST':
|
if method == 'POST':
|
||||||
sent_data = ToUtf8Json( data )
|
sent_data = ToUtf8Json( data )
|
||||||
return requests.post( _BuildUri( handler ),
|
return requests.post(
|
||||||
|
request_uri,
|
||||||
data = sent_data,
|
data = sent_data,
|
||||||
headers = BaseRequest._ExtraHeaders( sent_data ) )
|
headers = BaseRequest._ExtraHeaders( method,
|
||||||
|
request_uri,
|
||||||
|
sent_data ) )
|
||||||
if method == 'GET':
|
if method == 'GET':
|
||||||
return requests.get( _BuildUri( handler ),
|
return requests.get(
|
||||||
headers = BaseRequest._ExtraHeaders() )
|
request_uri,
|
||||||
|
headers = BaseRequest._ExtraHeaders( method, request_uri ) )
|
||||||
|
|
||||||
if not _CheckServerIsHealthyWithCache():
|
if not _CheckServerIsHealthyWithCache():
|
||||||
return _EXECUTOR.submit( DelayedSendRequest, data, handler, method )
|
return _EXECUTOR.submit( DelayedSendRequest, data, handler, method )
|
||||||
@ -120,12 +128,15 @@ class BaseRequest( object ):
|
|||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _ExtraHeaders( request_body = None ):
|
def _ExtraHeaders( method, request_uri, request_body = None ):
|
||||||
if not request_body:
|
if not request_body:
|
||||||
request_body = ''
|
request_body = ''
|
||||||
headers = dict( _HEADERS )
|
headers = dict( _HEADERS )
|
||||||
headers[ _HMAC_HEADER ] = b64encode(
|
headers[ _HMAC_HEADER ] = b64encode(
|
||||||
utils.CreateHexHmac( request_body, BaseRequest.hmac_secret ) )
|
CreateRequestHmac( method,
|
||||||
|
urlparse.urlparse( request_uri ).path,
|
||||||
|
request_body,
|
||||||
|
BaseRequest.hmac_secret ) )
|
||||||
return headers
|
return headers
|
||||||
|
|
||||||
session = FuturesSession( executor = _EXECUTOR )
|
session = FuturesSession( executor = _EXECUTOR )
|
||||||
@ -174,10 +185,9 @@ def HandleServerException( exception ):
|
|||||||
|
|
||||||
|
|
||||||
def _ValidateResponseObject( response ):
|
def _ValidateResponseObject( response ):
|
||||||
if not utils.ContentHexHmacValid(
|
hmac = CreateHmac( response.content, BaseRequest.hmac_secret )
|
||||||
response.content,
|
if not SecureStringsEqual( hmac,
|
||||||
b64decode( response.headers[ _HMAC_HEADER ] ),
|
b64decode( response.headers[ _HMAC_HEADER ] ) ):
|
||||||
BaseRequest.hmac_secret ):
|
|
||||||
raise RuntimeError( 'Received invalid HMAC for response!' )
|
raise RuntimeError( 'Received invalid HMAC for response!' )
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -191,8 +201,10 @@ def _CheckServerIsHealthyWithCache():
|
|||||||
global SERVER_HEALTHY
|
global SERVER_HEALTHY
|
||||||
|
|
||||||
def _ServerIsHealthy():
|
def _ServerIsHealthy():
|
||||||
response = requests.get( _BuildUri( 'healthy' ),
|
request_uri = _BuildUri( 'healthy' )
|
||||||
headers = BaseRequest._ExtraHeaders() )
|
response = requests.get( request_uri,
|
||||||
|
headers = BaseRequest._ExtraHeaders(
|
||||||
|
'GET', request_uri, '' ) )
|
||||||
_ValidateResponseObject( response )
|
_ValidateResponseObject( response )
|
||||||
response.raise_for_status()
|
response.raise_for_status()
|
||||||
return response.json()
|
return response.json()
|
||||||
|
2
third_party/ycmd
vendored
2
third_party/ycmd
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 954cf04c5f12228d385a8c2088443d5d7b303d48
|
Subproject commit 426833360adec8db72ed6cef9d7aa7f037e6a5b8
|
Loading…
x
Reference in New Issue
Block a user