| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | /////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //  Copyright (C) 2019-     Equinor ASA
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //  ResInsight is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | //  it under the terms of the GNU General Public License as published by
 | 
					
						
							|  |  |  | //  the Free Software Foundation, either version 3 of the License, or
 | 
					
						
							|  |  |  | //  (at your option) any later version.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //  ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY
 | 
					
						
							|  |  |  | //  WARRANTY; without even the implied warranty of MERCHANTABILITY or
 | 
					
						
							|  |  |  | //  FITNESS FOR A PARTICULAR PURPOSE.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //  See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
 | 
					
						
							|  |  |  | //  for more details.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-03 14:33:16 +02:00
										 |  |  | #include "Case.grpc.pb.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "RiaGrpcServiceInterface.h"
 | 
					
						
							|  |  |  | #include "RiaPorosityModel.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace rips | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-06-03 14:33:16 +02:00
										 |  |  | class CaseRequest; | 
					
						
							| 
									
										
										
										
											2019-06-10 20:42:20 +02:00
										 |  |  | class PdmObject; | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  | } // namespace rips
 | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-27 07:29:20 +02:00
										 |  |  | class RiaGrpcCallbackInterface; | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | class RigCell; | 
					
						
							|  |  |  | class RigActiveCellInfo; | 
					
						
							|  |  |  | class RimEclipseCase; | 
					
						
							| 
									
										
										
										
											2020-02-19 15:20:34 +01:00
										 |  |  | class RiuEclipseSelectionItem; | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | //==================================================================================================
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // State handler for streaming of active cell info
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //==================================================================================================
 | 
					
						
							|  |  |  | class RiaActiveCellInfoStateHandler | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     typedef grpc::Status Status; | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-21 13:40:42 +02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  |     RiaActiveCellInfoStateHandler(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  |     Status init( const rips::CellInfoRequest* request ); | 
					
						
							| 
									
										
										
										
											2020-02-17 17:46:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     RigActiveCellInfo*          activeCellInfo() const; | 
					
						
							|  |  |  |     const std::vector<RigCell>& reservoirCells() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // For cell info:
 | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  |     Status assignNextActiveCellInfoData( rips::CellInfo* cellInfo ); | 
					
						
							|  |  |  |     void   assignCellInfoData( rips::CellInfo* cellInfo, const std::vector<RigCell>& reservoirCells, size_t cellIdx ); | 
					
						
							|  |  |  |     Status assignReply( rips::CellInfoArray* reply ); | 
					
						
							| 
									
										
										
										
											2020-02-17 17:46:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // For cell centers:
 | 
					
						
							|  |  |  |     Status assignNextActiveCellCenter( rips::Vec3d* cellCenter ); | 
					
						
							|  |  |  |     void   assignCellCenter( rips::Vec3d* cellCenter, const std::vector<RigCell>& reservoirCells, size_t cellIdx ); | 
					
						
							|  |  |  |     Status assignCellCentersReply( rips::CellCenters* reply ); | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-19 11:33:25 +01:00
										 |  |  |     // For cell corners:
 | 
					
						
							|  |  |  |     Status assignNextActiveCellCorners( rips::CellCorners* cellCorners ); | 
					
						
							|  |  |  |     void assignCellCorners( rips::CellCorners* cellCorners, const std::vector<RigCell>& reservoirCells, size_t cellIdx ); | 
					
						
							|  |  |  |     Status assignCellCornersReply( rips::CellCornersArray* reply ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | protected: | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  |     const rips::CellInfoRequest*  m_request; | 
					
						
							|  |  |  |     RimEclipseCase*               m_eclipseCase; | 
					
						
							|  |  |  |     RiaDefines::PorosityModelType m_porosityModel; | 
					
						
							|  |  |  |     RigActiveCellInfo*            m_activeCellInfo; | 
					
						
							|  |  |  |     std::vector<size_t>           m_globalCoarseningBoxIndexStart; | 
					
						
							|  |  |  |     size_t                        m_currentCellIdx; | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-19 15:20:34 +01:00
										 |  |  | //==================================================================================================
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // State handler for streaming of selected cells
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //==================================================================================================
 | 
					
						
							|  |  |  | class RiaSelectedCellsStateHandler | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     typedef grpc::Status Status; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     RiaSelectedCellsStateHandler(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Status init( const rips::CaseRequest* request ); | 
					
						
							|  |  |  |     Status assignReply( rips::SelectedCells* reply ); | 
					
						
							|  |  |  |     void   assignSelectedCell( rips::SelectedCell* cell, const RiuEclipseSelectionItem* item ); | 
					
						
							|  |  |  |     Status assignNextSelectedCell( rips::SelectedCell* cell, const std::vector<RiuEclipseSelectionItem*>& items ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     const rips::CaseRequest* m_request; | 
					
						
							|  |  |  |     RimEclipseCase*          m_eclipseCase; | 
					
						
							|  |  |  |     size_t                   m_currentItem; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | //==================================================================================================
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // gRPC-service answering requests about grid information for a given case
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //==================================================================================================
 | 
					
						
							| 
									
										
										
										
											2019-06-03 14:33:16 +02:00
										 |  |  | class RiaGrpcCaseService final : public rips::Case::AsyncService, public RiaGrpcServiceInterface | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  |     grpc::Status | 
					
						
							|  |  |  |                  GetGridCount( grpc::ServerContext* context, const rips::CaseRequest* request, rips::GridCount* reply ) override; | 
					
						
							|  |  |  |     grpc::Status GetCellCount( grpc::ServerContext*         context, | 
					
						
							|  |  |  |                                const rips::CellInfoRequest* request, | 
					
						
							|  |  |  |                                rips::CellCount*             reply ) override; | 
					
						
							|  |  |  |     grpc::Status GetTimeSteps( grpc::ServerContext*     context, | 
					
						
							|  |  |  |                                const rips::CaseRequest* request, | 
					
						
							|  |  |  |                                rips::TimeStepDates*     reply ) override; | 
					
						
							|  |  |  |     grpc::Status GetDaysSinceStart( grpc::ServerContext*     context, | 
					
						
							|  |  |  |                                     const rips::CaseRequest* request, | 
					
						
							|  |  |  |                                     rips::DaysSinceStart*    reply ) override; | 
					
						
							| 
									
										
										
										
											2020-02-12 11:43:15 +01:00
										 |  |  |     grpc::Status GetCaseInfo( grpc::ServerContext* context, const rips::CaseRequest* request, rips::CaseInfo* reply ) override; | 
					
						
							| 
									
										
										
										
											2019-09-06 10:40:57 +02:00
										 |  |  |     grpc::Status | 
					
						
							| 
									
										
										
										
											2020-01-23 14:43:51 +01:00
										 |  |  |                  GetPdmObject( grpc::ServerContext* context, const rips::CaseRequest* request, rips::PdmObject* reply ) override; | 
					
						
							|  |  |  |     grpc::Status GetCellInfoForActiveCells( grpc::ServerContext*           context, | 
					
						
							|  |  |  |                                             const rips::CellInfoRequest*   request, | 
					
						
							|  |  |  |                                             rips::CellInfoArray*           reply, | 
					
						
							|  |  |  |                                             RiaActiveCellInfoStateHandler* stateHandler ); | 
					
						
							| 
									
										
										
										
											2020-02-17 17:46:15 +01:00
										 |  |  |     grpc::Status GetCellCenterForActiveCells( grpc::ServerContext*           context, | 
					
						
							|  |  |  |                                               const rips::CellInfoRequest*   request, | 
					
						
							|  |  |  |                                               rips::CellCenters*             reply, | 
					
						
							|  |  |  |                                               RiaActiveCellInfoStateHandler* stateHandler ); | 
					
						
							| 
									
										
										
										
											2020-02-19 11:33:25 +01:00
										 |  |  |     grpc::Status GetCellCornersForActiveCells( grpc::ServerContext*           context, | 
					
						
							|  |  |  |                                                const rips::CellInfoRequest*   request, | 
					
						
							|  |  |  |                                                rips::CellCornersArray*        reply, | 
					
						
							|  |  |  |                                                RiaActiveCellInfoStateHandler* stateHandler ); | 
					
						
							| 
									
										
										
										
											2020-02-19 15:20:34 +01:00
										 |  |  |     grpc::Status GetSelectedCells( grpc::ServerContext*          context, | 
					
						
							|  |  |  |                                    const rips::CaseRequest*      request, | 
					
						
							|  |  |  |                                    rips::SelectedCells*          reply, | 
					
						
							|  |  |  |                                    RiaSelectedCellsStateHandler* stateHandler ); | 
					
						
							| 
									
										
										
										
											2020-01-23 14:43:51 +01:00
										 |  |  |     grpc::Status GetReservoirBoundingBox( grpc::ServerContext*     context, | 
					
						
							|  |  |  |                                           const rips::CaseRequest* request, | 
					
						
							| 
									
										
										
										
											2020-09-14 21:47:48 +02:00
										 |  |  |                                           rips::BoundingBox*       reply ) override; | 
					
						
							| 
									
										
										
										
											2020-02-20 21:40:43 +01:00
										 |  |  |     grpc::Status GetCoarseningInfoArray( grpc::ServerContext*       context, | 
					
						
							|  |  |  |                                          const rips::CaseRequest*   request, | 
					
						
							| 
									
										
										
										
											2020-09-14 21:47:48 +02:00
										 |  |  |                                          rips::CoarseningInfoArray* reply ) override; | 
					
						
							| 
									
										
										
										
											2020-01-23 14:43:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-27 07:29:20 +02:00
										 |  |  |     std::vector<RiaGrpcCallbackInterface*> createCallbacks() override; | 
					
						
							| 
									
										
										
										
											2019-05-20 13:21:02 +02:00
										 |  |  | }; |