blob: c384cb2060f3e9702478f685918c4d6b628a2739 [file] [log] [blame]
Naveen Sampath04696f72022-06-13 15:19:14 +05301/*
2* Copyright 2022-present Open Networking Foundation
3* Licensed under the Apache License, Version 2.0 (the "License");
4* you may not use this file except in compliance with the License.
5* You may obtain a copy of the License at
6*
7* http://www.apache.org/licenses/LICENSE-2.0
8*
9* Unless required by applicable law or agreed to in writing, software
10* distributed under the License is distributed on an "AS IS" BASIS,
11* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12* See the License for the specific language governing permissions and
13* limitations under the License.
14 */
15
16package vpagent
17
18import (
19 "context"
20 "errors"
21 "time"
22
Tinoj Joseph1d108322022-07-13 10:07:39 +053023 "voltha-go-controller/log"
vinokuma926cb3e2023-03-29 11:41:06 +053024
25 "github.com/golang/protobuf/ptypes/empty"
Abhay Kumarbe5b5bd2025-12-09 08:47:09 +000026 grpc_middleware "github.com/grpc-ecosystem/go-grpc-middleware"
27 grpc_prometheus "github.com/grpc-ecosystem/go-grpc-prometheus"
Naveen Sampath04696f72022-06-13 15:19:14 +053028 "github.com/opencord/voltha-protos/v5/go/voltha"
Abhay Kumarbe5b5bd2025-12-09 08:47:09 +000029
Naveen Sampath04696f72022-06-13 15:19:14 +053030 "google.golang.org/grpc"
Abhay Kumarfe505f22025-11-10 14:16:31 +000031 "google.golang.org/grpc/credentials/insecure"
Naveen Sampath04696f72022-06-13 15:19:14 +053032)
33
vinokuma926cb3e2023-03-29 11:41:06 +053034// GrpcMaxSize Max size of grpc message
Naveen Sampath04696f72022-06-13 15:19:14 +053035const GrpcMaxSize int = 17455678
36
Akash Sonief452f12024-12-12 18:20:28 +053037func (vpa *VPAgent) establishConnectionToVoltha(ctx context.Context) error {
Naveen Sampath04696f72022-06-13 15:19:14 +053038 if vpa.volthaConnection != nil {
mgoudabb017dc2025-10-29 19:53:34 +053039 _ = vpa.volthaConnection.Close()
Naveen Sampath04696f72022-06-13 15:19:14 +053040 }
41
42 vpa.volthaConnection = nil
43 vpa.volthaClient.Clear()
44 try := 1
Abhay Kumarbe5b5bd2025-12-09 08:47:09 +000045 grpc_prometheus.EnableClientHandlingTimeHistogram()
Naveen Sampath04696f72022-06-13 15:19:14 +053046 for vpa.ConnectionMaxRetries == 0 || try < vpa.ConnectionMaxRetries {
Abhay Kumarbe5b5bd2025-12-09 08:47:09 +000047 conn, err := grpc.NewClient(vpa.VolthaAPIEndPoint,
48 grpc.WithTransportCredentials(insecure.NewCredentials()),
49 grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(GrpcMaxSize)),
50 grpc.WithStreamInterceptor(grpc_middleware.ChainStreamClient(
51 grpc_prometheus.StreamClientInterceptor,
52 )),
53 grpc.WithUnaryInterceptor(grpc_middleware.ChainUnaryClient(
54 grpc_prometheus.UnaryClientInterceptor,
55 )))
56
Naveen Sampath04696f72022-06-13 15:19:14 +053057 if err == nil {
58 svc := voltha.NewVolthaServiceClient(conn)
59 if svc != nil {
60 if _, err = svc.GetVoltha(context.Background(), &empty.Empty{}); err == nil {
61 logger.Debugw(ctx, "Established connection to Voltha",
62 log.Fields{
63 "VolthaApiEndPoint": vpa.VolthaAPIEndPoint,
64 })
65 vpa.volthaConnection = conn
66 vpa.volthaClient.Set(svc)
Naveen Sampath04696f72022-06-13 15:19:14 +053067 vpa.events <- vpaEventVolthaConnected
68 return nil
69 }
70 }
71 }
Akash Soni634d9bf2023-07-10 12:11:10 +053072 logger.Errorw(ctx, "Failed to connect to voltha",
Naveen Sampath04696f72022-06-13 15:19:14 +053073 log.Fields{
74 "VolthaApiEndPoint": vpa.VolthaAPIEndPoint,
75 "error": err.Error(),
76 })
77 if vpa.ConnectionMaxRetries == 0 || try < vpa.ConnectionMaxRetries {
78 if vpa.ConnectionMaxRetries != 0 {
79 try++
80 }
81 time.Sleep(vpa.ConnectionRetryDelay)
82 }
83 }
Naveen Sampath04696f72022-06-13 15:19:14 +053084 return errors.New("failed-to-connect-to-voltha")
85}
86
87// CloseConnectionToVoltha closes the grpc connection to VOLTHA
88func (vpa *VPAgent) CloseConnectionToVoltha() {
vinokuma926cb3e2023-03-29 11:41:06 +053089 // Close the grpc connection to voltha
Naveen Sampath04696f72022-06-13 15:19:14 +053090 logger.Debug(ctx, "Closing voltha grpc connection")
mgoudabb017dc2025-10-29 19:53:34 +053091 _ = vpa.volthaConnection.Close()
Naveen Sampath04696f72022-06-13 15:19:14 +053092}