blob: e6d7945a3b1e4eb5d10bea9debcab2f2bf23fe20 [file] [log] [blame]
#ifdef BAL_STUB
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <signal.h>
#include "bal_stub.h"
#include "bal_msg_type.grpc-c.h"
#include "bal_osmsg.grpc-c.h"
#include "bal_model_ids.grpc-c.h"
#include "bal_obj.grpc-c.h"
#include "bal_model_types.grpc-c.h"
#include "bal_errno.grpc-c.h"
#include "bal_indications.grpc-c.h"
#include "bal.grpc-c.h"
void *stub_thread(void *v)
{
int status;
grpc_c_client_t *client = grpc_c_client_init("172.24.150.114:60001", "bal_client", NULL);
pthread_mutex_lock(&lock);
pthread_cond_wait(&cv, &lock);
while(NULL != shared_queue->front)
{
BalObjId prevObjType;
struct QNode *front = deQueue(shared_queue);
/* prepare and send rpc response */
BalIndications balIndCfg;
memset(&balIndCfg, 0, sizeof(BalIndications));
bal_indications__init(&balIndCfg);
BalObjInd bal_obj_ind;
memset(&bal_obj_ind, 0, sizeof(BalObjInd));
bal_obj_ind__init(&bal_obj_ind);
balIndCfg.u_case = BAL_INDICATIONS__U_BAL_OBJ_INFO;
balIndCfg.balobjinfo = &bal_obj_ind;
balIndCfg.balobjinfo->has_objtype = 1;
balIndCfg.balobjinfo->objtype = front->obj_type;
balIndCfg.balobjinfo->has_status = 1;
balIndCfg.balobjinfo->status = front->status;
char keystr;
balIndCfg.balobjinfo->keystr = &keystr;
switch(front->obj_type)
{
case BAL_OBJ_ID__BAL_OBJ_ID_ACCESS_TERMINAL:
{
printf("***************************************************\n");
printf("Successful Indication sent for ACCESS_TERMINAL\n");
printf("***************************************************\n");
balIndCfg.balobjinfo->u_case = BAL_OBJ_IND__U__NOT_SET;
prevObjType = front->obj_type;
}
break;
case BAL_OBJ_ID__BAL_OBJ_ID_INTERFACE:
{
printf("***************************************************\n");
printf("Successful Indication sent for PON INTERFACE UP\n");
printf("***************************************************\n");
balIndCfg.balobjinfo->u_case = BAL_OBJ_IND__U__NOT_SET;
prevObjType = front->obj_type;
}
break;
case BAL_OBJ_ID__BAL_OBJ_ID_SUBSCRIBER_TERMINAL:
{
balIndCfg.balobjinfo->u_case = BAL_OBJ_IND__U_ONU_DISCOVERY_INFO;
BalSubscriberTerminalCfg onudiscoveryinfo;
memset(&onudiscoveryinfo, 0, sizeof(BalSubscriberTerminalCfg));
bal_subscriber_terminal_cfg__init(&onudiscoveryinfo);
balIndCfg.balobjinfo->onudiscoveryinfo = &onudiscoveryinfo;
BalSubscriberTerminalKey subTermKey;
memset(&subTermKey, 0, sizeof(BalSubscriberTerminalKey));
bal_subscriber_terminal_key__init(&subTermKey);
balIndCfg.balobjinfo->onudiscoveryinfo->key = &subTermKey;
balIndCfg.balobjinfo->onudiscoveryinfo->key->has_sub_term_id = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->key->sub_term_id = 65535;
balIndCfg.balobjinfo->onudiscoveryinfo->key->has_intf_id = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->key->intf_id = 0;
BalSubscriberTerminalCfgData subTermCfgData;
memset(&subTermCfgData, 0, sizeof(BalSubscriberTerminalCfgData));
bal_subscriber_terminal_cfg_data__init(&subTermCfgData);
balIndCfg.balobjinfo->onudiscoveryinfo->data = &subTermCfgData;
if(BAL_OBJ_ID__BAL_OBJ_ID_INTERFACE == prevObjType)
{
balIndCfg.balobjinfo->onudiscoveryinfo->data->has_admin_state = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->data->admin_state = BAL_STATE__BAL_STATE_DOWN;
balIndCfg.balobjinfo->onudiscoveryinfo->data->has_oper_status = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->data->oper_status = BAL_STATUS__BAL_STATUS_DOWN;
printf("\n***************************************************\n");
printf("Sending ONU discovery message\n");
printf("***************************************************\n");
}
else
{
balIndCfg.balobjinfo->onudiscoveryinfo->data->has_admin_state = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->data->admin_state = BAL_STATE__BAL_STATE_UP;
balIndCfg.balobjinfo->onudiscoveryinfo->data->has_oper_status = 1;
balIndCfg.balobjinfo->onudiscoveryinfo->data->oper_status = BAL_STATUS__BAL_STATUS_UP;
printf("***************************************************\n");
printf("ONU Activation Successful\n");
printf("***************************************************\n");
}
BalSerialNumber serial_number;
memset(&serial_number, 0, sizeof(BalSerialNumber));
bal_serial_number__init(&serial_number);
balIndCfg.balobjinfo->onudiscoveryinfo->data->serial_number = &serial_number;
char vendor_id[20];
memset(&vendor_id, 0, 20);
strcpy(vendor_id,"4252434D");
balIndCfg.balobjinfo->onudiscoveryinfo->data->serial_number->vendor_id = vendor_id;
char vendor_specific[20];
memset(&vendor_specific, 0, 20);
strcpy(vendor_specific,"12345678");
balIndCfg.balobjinfo->onudiscoveryinfo->data->serial_number->vendor_specific = vendor_specific;
prevObjType = front->obj_type;
}
break;
case BAL_OBJ_ID__BAL_OBJ_ID_PACKET:
{
balIndCfg.balobjinfo->u_case = BAL_OBJ_IND__U_PKT_DATA;
}
break;
default:
{
balIndCfg.balobjinfo->u_case = BAL_OBJ_IND__U__NOT_SET;
prevObjType = front->obj_type;
}
break;
}
BalErr *output;
status = bal_ind__bal_ind_info(client, NULL, &balIndCfg, &output, NULL, 0);
free(front);
pthread_mutex_unlock(&lock);
pthread_mutex_lock(&lock);
pthread_cond_wait(&cv, &lock);
}
return NULL;
}
void create_stub_thread()
{
pthread_t threadId = 0;
/* create shared queue */
shared_queue = createQueue();
pthread_create(&threadId, NULL, stub_thread, NULL);
}
/* A utility function to create an empty queue */
bal_queue *createQueue()
{
shared_queue = (struct Queue*)malloc(sizeof(struct Queue));
shared_queue->front = shared_queue->rear = NULL;
return shared_queue;
}
/* A utility function to create a new linked list node */
struct QNode* newNode(int objKey, int status)
{
struct QNode *temp = (struct QNode*)malloc(sizeof(struct QNode));
temp->obj_type = objKey;
temp->status = status;
temp->next = NULL;
return temp;
}
/* The function to add data to shared_queue - Add end of the queue */
void enQueue(int objKey, int status)
{
/* Create a new LL node */
struct QNode *temp = newNode(objKey, status);
/* If queue is empty, then new node is front and rear both */
if (shared_queue->rear == NULL)
{
shared_queue->front = shared_queue->rear = temp;
return;
}
/* Add the new node at the end of queue and change rear */
shared_queue->rear->next = temp;
shared_queue->rear = temp;
}
/* Function to remove data from shared_queue - FIFO */
struct QNode *deQueue()
{
/* If queue is empty, return NULL */
if (shared_queue->front == NULL)
{
return NULL;
}
/* Store previous front and move front one node ahead */
struct QNode *temp = shared_queue->front;
shared_queue->front = shared_queue->front->next;
/* If front becomes NULL, then change rear also as NULL */
if (shared_queue->front == NULL)
{
shared_queue->rear = NULL;
}
return temp;
}
#endif