Exemplo n.º 1
0
        private static void OnRejection(Message message, IResponseCompletionSource context)
        {
            Exception rejection;

            switch (message.RejectionType)
            {
            case Message.RejectionTypes.GatewayTooBusy:
                rejection = new GatewayTooBusyException();
                break;

            case Message.RejectionTypes.DuplicateRequest:
                return;     // Ignore duplicates

            default:
                rejection = message.BodyObject as Exception;
                if (rejection == null)
                {
                    if (string.IsNullOrEmpty(message.RejectionInfo))
                    {
                        message.RejectionInfo = "Unable to send request - no rejection info available";
                    }
                    rejection = new OrleansMessageRejectionException(message.RejectionInfo);
                }
                break;
            }

            context.Complete(Response.FromException(rejection));
        }
Exemplo n.º 2
0
        private void ResponseCallback(Message message, TaskCompletionSource <object> context)
        {
            Response response;

            if (message.Result != Message.ResponseTypes.Rejection)
            {
                try
                {
                    response = (Response)message.GetDeserializedBody(this.serializationManager);
                }
                catch (Exception exc)
                {
                    //  catch the Deserialize exception and break the promise with it.
                    response = Response.ExceptionResponse(exc);
                }
            }
            else
            {
                Exception rejection;
                switch (message.RejectionType)
                {
                case Message.RejectionTypes.GatewayTooBusy:
                    rejection = new GatewayTooBusyException();
                    break;

                case Message.RejectionTypes.DuplicateRequest:
                    return;     // Ignore duplicates

                default:
                    rejection = message.GetDeserializedBody(this.serializationManager) as Exception;
                    if (rejection == null)
                    {
                        if (string.IsNullOrEmpty(message.RejectionInfo))
                        {
                            message.RejectionInfo = "Unable to send request - no rejection info available";
                        }
                        rejection = new OrleansMessageRejectionException(message.RejectionInfo);
                    }
                    break;
                }
                response = Response.ExceptionResponse(rejection);
            }

            if (!response.ExceptionFlag)
            {
                context.TrySetResult(response.Data);
            }
            else
            {
                context.TrySetException(response.Exception);
            }
        }