2019-05-20 06:21:02 -05: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 07:33:16 -05:00
|
|
|
#include "Case.grpc.pb.h"
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
#include "RiaGrpcServiceInterface.h"
|
|
|
|
#include "RiaPorosityModel.h"
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace rips
|
|
|
|
{
|
2019-06-03 07:33:16 -05:00
|
|
|
class CaseRequest;
|
2019-06-10 13:42:20 -05:00
|
|
|
class PdmObject;
|
2019-09-06 03:40:57 -05:00
|
|
|
} // namespace rips
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
class RiaGrpcCallbackInterface;
|
2019-05-20 06:21:02 -05:00
|
|
|
class RigCell;
|
|
|
|
class RigActiveCellInfo;
|
|
|
|
class RimEclipseCase;
|
2020-02-19 08:20:34 -06:00
|
|
|
class RiuEclipseSelectionItem;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
//
|
|
|
|
// State handler for streaming of active cell info
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
|
|
|
class RiaActiveCellInfoStateHandler
|
|
|
|
{
|
|
|
|
typedef grpc::Status Status;
|
2019-09-06 03:40:57 -05:00
|
|
|
|
2019-05-21 06:40:42 -05:00
|
|
|
public:
|
2019-05-20 06:21:02 -05:00
|
|
|
RiaActiveCellInfoStateHandler();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
Status init( const rips::CellInfoRequest* request );
|
2020-02-17 10:46:15 -06:00
|
|
|
|
|
|
|
RigActiveCellInfo* activeCellInfo() const;
|
|
|
|
const std::vector<RigCell>& reservoirCells() const;
|
|
|
|
|
|
|
|
// For cell info:
|
2019-09-06 03:40:57 -05: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 10:46:15 -06: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 06:21:02 -05:00
|
|
|
|
2020-02-19 04:33:25 -06: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 06:21:02 -05:00
|
|
|
protected:
|
2019-09-06 03:40:57 -05: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 06:21:02 -05:00
|
|
|
};
|
|
|
|
|
2020-02-19 08:20:34 -06: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 06:21:02 -05:00
|
|
|
//==================================================================================================
|
|
|
|
//
|
|
|
|
// gRPC-service answering requests about grid information for a given case
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-06-03 07:33:16 -05:00
|
|
|
class RiaGrpcCaseService final : public rips::Case::AsyncService, public RiaGrpcServiceInterface
|
2019-05-20 06:21:02 -05:00
|
|
|
{
|
|
|
|
public:
|
2019-09-06 03:40:57 -05: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 04:43:15 -06:00
|
|
|
grpc::Status GetCaseInfo( grpc::ServerContext* context, const rips::CaseRequest* request, rips::CaseInfo* reply ) override;
|
2019-09-06 03:40:57 -05:00
|
|
|
grpc::Status
|
2020-01-23 07:43:51 -06: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 10:46:15 -06:00
|
|
|
grpc::Status GetCellCenterForActiveCells( grpc::ServerContext* context,
|
|
|
|
const rips::CellInfoRequest* request,
|
|
|
|
rips::CellCenters* reply,
|
|
|
|
RiaActiveCellInfoStateHandler* stateHandler );
|
2020-02-19 04:33:25 -06:00
|
|
|
grpc::Status GetCellCornersForActiveCells( grpc::ServerContext* context,
|
|
|
|
const rips::CellInfoRequest* request,
|
|
|
|
rips::CellCornersArray* reply,
|
|
|
|
RiaActiveCellInfoStateHandler* stateHandler );
|
2020-02-19 08:20:34 -06:00
|
|
|
grpc::Status GetSelectedCells( grpc::ServerContext* context,
|
|
|
|
const rips::CaseRequest* request,
|
|
|
|
rips::SelectedCells* reply,
|
|
|
|
RiaSelectedCellsStateHandler* stateHandler );
|
2020-01-23 07:43:51 -06:00
|
|
|
grpc::Status GetReservoirBoundingBox( grpc::ServerContext* context,
|
|
|
|
const rips::CaseRequest* request,
|
2020-09-14 14:47:48 -05:00
|
|
|
rips::BoundingBox* reply ) override;
|
2020-02-20 14:40:43 -06:00
|
|
|
grpc::Status GetCoarseningInfoArray( grpc::ServerContext* context,
|
|
|
|
const rips::CaseRequest* request,
|
2020-09-14 14:47:48 -05:00
|
|
|
rips::CoarseningInfoArray* reply ) override;
|
2020-01-23 07:43:51 -06:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
std::vector<RiaGrpcCallbackInterface*> createCallbacks() override;
|
2019-05-20 06:21:02 -05:00
|
|
|
};
|