Systems and Methods to Construct Engineering Environment Supporting API Enablement for Software Defined Networking

Abstract
The embodiments herein relate to software defined networking (SDN) and, more particularly, to a system and method to construct an engineering environment for API enablement in Software defined networking. The system enables the device use SDN functionality by designing an API model specific to that device. In order to design the device specific API model, an API enablement system initially leverages functionality/capabilities of the device. Further, by analyzing the leveraged device capabilities, the system designs the API model for the device. After implementing the API model on the device, the system performs a review function to ensure that the designed API model is in compliance with set rules and policies. The API model may be refined based on results of the review function.
Description

The present application is based on, and claims priority from, IN Application Number 2671/CHE/2013, filed on 19 Jun. 2013, the disclosure of which is hereby incorporated by reference herein.


TECHNICAL FIELD

The embodiments herein relate to software defined networking (SDN) and, more particularly, to a system and method to construct an engineering environment for API enablement for Software defined networking.


BACKGROUND

Software Defined Networking (SDN) is an approach to networking in which control plane is separated from data plane and control plane is implemented in a software application called controller. SDN controller which initiates and manages and terminates the traffic in the network environment such as network virtualization, network monitoring, flow balancing, etc.


With the inception of Software Defined Networking (SDN) technologies, network industry already started adopting SDN. It is very expensive to replace all the conventional network products which do not support SDN functionality. Vast ranges of legacy products now require simpler and effective way to support programmability for a flexible deployment in networked environment. While Telecom Networking & Server Storage elements become the primary candidate for adopting the programmability support, other specialized elements like medical devices, office automation elements, aerospace devices, networked automobile devices and the firmware & chip based platforms are also experiencing the need to support programmability for more flexible deployment in the specialized networks. Thus, a need to extend the capabilities of the legacy products is necessary.


There is a need for a system and method to provide programmability support for legacy products which already exist in the market.


SUMMARY

In view of the foregoing, an embodiment herein provides a method of enabling Application Programming Interface (API) support for a device; the method comprises leveraging capabilities of the device; designing an API model based on the leveraged device capabilities; reviewing the designed API model; and implementing the API model on the device.


Embodiments further disclose a system of enabling Application Programming Interface (API) support for a device; the system configured for leveraging capabilities of the device using an IDE server; designing an API model based on the leveraged device capabilities using the IDE server; reviewing the designed API model using the IDE server; and implementing the API model on the device using the IDE server.


These and other aspects of the embodiments herein will be better appreciated and understood when considered in conjunction with the following description and the accompanying drawings.





BRIEF DESCRIPTION OF THE FIGURES

The embodiments herein will be better understood from the following detailed description with reference to the drawings, in which:



FIG. 1 illustrates a block diagram of a Application Programming Interface (API) enablement system, as disclosed in the embodiments herein;



FIG. 2 illustrates a block diagram which shows various components of Integrated Development Environment (IDE) in the API enablement system, as disclosed in the embodiments herein;



FIG. 3 is a flow diagram which shows various steps involved in the process of enabling SDN on a device using API enablement system, as disclosed in the embodiments herein;



FIG. 4 is a flow diagram which shows various steps involved in the process of analyzing device functionality and designing API module for the device, as disclosed in the embodiments herein;



FIG. 5 is a flow diagram which shows various steps involved in the process of reviewing API model of a device, as disclosed in the embodiments herein;



FIGS. 6A and 6B illustrate block diagrams which shows external and internal implementation of the API module in the SDN enablement system, as disclosed in the embodiments herein; and



FIG. 7 illustrates a computing environment implementing the API enablement system, according to embodiments as disclosed herein.





DETAILED DESCRIPTION OF EMBODIMENTS

The embodiments herein and the various features and advantageous details thereof are explained more fully with reference to the non-limiting embodiments that are illustrated in the accompanying drawings and detailed in the following description. Descriptions of well-known components and processing techniques are omitted so as to not unnecessarily obscure the embodiments herein. The examples used herein are intended merely to facilitate an understanding of ways in which the embodiments herein may be practiced and to further enable those of skill in the art to practice the embodiments herein. Accordingly, the examples should not be construed as limiting the scope of the embodiments herein.


The embodiments herein disclose a system and method to construct an engineering environment to enable software defined networking (SDN) of a legacy product/device, which does not have SDN capability. Referring now to the drawings, and more particularly to FIG. 1 through 7, where similar reference characters denote corresponding features consistently throughout the figures, there are shown embodiments.



FIG. 1 illustrates a block diagram of a Application Programming Interface (API) enablement system, as disclosed in the embodiments herein. The API enablement system 100 comprises an IDE client 101, an IDE server 102, a device 103 and an API module 104. The IDE client 101 represents a front end system which may act as an interface to access, monitor and control any operations or functionalities of the IDE server 102 and the device 103. The device 103 may refer to any device such as router which has to be provided with the SDN functionality. In a preferred embodiment, all communication between the device 103 and the IDE client 101 is through the IDE server 102. In another embodiment, the IDE client 101, IDE server 102 and the device 103 may be communicating using a suitable interface such as a web based interface.


An API enablement environment is set up by connecting the device 103, IDE client 101 and the IDE server 102 as depicted in the FIG. 1. The API enablement system 100 helps the device 103 to use the SDN functionality by designing a API module 104 that matches configuration of the device 103. The process of designing the API module 104 for the device 103 involves two phases namely analysis and design phase and a review phase. In the analysis and design phase, the IDE server 102 initially identifies capabilities of the device 103 by fetching, analyzing and processing specific data from the device 103. Further, based on the identified device capabilities, the IDE server 103 designs an API module 104 with compliance for certain pre-defined rules and policies so as to enable the device 103 use the desired SDN functionality. The designed API module 104 is implemented on top of the device 103 and further in the review phase, the IDE server 102 conducts specific tests and checks whether the designed API module 104 is in compliance with the defined set of rules and policies.



FIG. 2 illustrates a block diagram which shows various components of Integrated Development Environment (IDE) server in the API enablement system, as disclosed in the embodiments herein. The IDE server 102 comprises of an IDE frontend 201 and an IDE backend 202. The IDE backend 202 further comprises of a rule meta model 202.a, a rapid analyzer 202.b, a rapid reviewer 202.c, a rapid designer 202.d and a database 202.e. The IDE frontend 201 provides means for any authorized user to remotely connect and access the device 103 and the IDE server 102 for providing any input or control commands required for the system. In a preferred embodiment, two set of inputs are required by the system; a first set being monitoring, control and management commands required to evaluate the device's 103 existing capabilities and the second set being a set of rules that are required to ensure that an API schema generated for that particular device 103 is meeting a required level of compliance for standard as well as proprietary rules.


The rule meta model 202.a is designed based on inputs such as implementation specific rules, standard specification compliance rules, vendor specific rules and so on. The rule meta model 202.a provides options to define rules at functional, module and attribute levels and set priorities to provide overwriting criteria required for rule enforcement.


The rapid analyzer 202.b is responsible for determining discoverable, monitor-able, configurable methods for programmability, and Identification of mandatory attributes for rules and policy compliance. When the analysis and design phase is initiated, the rapid analyzer 202.b intercepts command and control signals/data from the network connected to device 103, inspects and develops a knowledge-base on available monitoring and control capabilities supported in the device 103. The rapid analyzer 202.b further identifies mode of communication required to carry out the command and control activities, and details out the attribute level support along with boundaries and validations.


The rapid designer 202.d is responsible for meta-model based referencing of APIs; dictionary linked annotations, and integrating validation rule/remarks into the API design. The rapid designer 202.d may compare identified command and control APIs against data in the rule meta model 202.a and assesses the level of compliance and non-compliance. Further, based on the assessment, the rapid designer 202.d annotates and generates a schema of supported APIs for the device 103. In a preferred embodiment, the schema may be device specific and may depend on capabilities of the device 103. In another embodiment, identical devices or different devices 103 having same set of capabilities/functionalities may have same set of API schema.


Once the schema has been generated, the rapid reviewer 202.c performs a review operation to ensure that the designed/generated schema is in compliance with set rules/policies. The review operation may involve a reverse validation of designed APIs, cross comparison of command & control communication, and reviewing of rules and policy compliance. The review may be performed by initiating specific command and control operations by executing specific unit tests in the device, monitoring ongoing communication in the device 103 and mapping the same onto the designed API data model. Further, the rapid reviewer 202.c refers to the enforced rules and validations applicable for the relevant tests, and conducts the unit tests in different system condition to review the results in maximum possible network scenarios.


Further, based on the analysis results, the system designs the structure of API module 104 with data associated with API data model and mapping, refined/selected programmability rules and API annotation and documentation. Further, results and other data associated with each review function is recorded as “review records”.



FIG. 3 is a flow diagram which shows various steps involved in the process of enabling SDN on a device using API enablement system, as disclosed in the embodiments herein. The SDN enablement system enabled a non SDN device 101 to use SDN functionality by creating a wraparound layer which is then implemented on top of the device 103 in the form of API module 104. The API module may be device specific and is designed based on capabilities of the device 101. Initially, the SDN enablement system leverages (302) the device's capabilities. During this process, the device's capabilities are analyzed and reviewed. Further, the leveraged information is analyzed and requirements to enable the device 101 to use SDN functionality are identified. Based on the identified requirements, the API module 104 is designed (304) and the specifications and capabilities to enable the device 101 to use the SDN functionality are associated with the API data model and mapping model and programmability rules in the API module 104. Further, assessment of unit test results fetched after executing the unit tests on the device 103 are iteratively done for each such emulation of progressive conditions against the API calls, and the feedback/results of the test are stored as review records. The review records may be then taken up as input for further refinement of API enablement functionalities. Further, the records and/or functionalities of the API module 102 are reviewed (306) to check and verify that all required compliance are met. The review process may also be used to update the API data model and mapping model and programmability rules, if required. The API module 104 is then connected to the device 103 which further acts as a layer that provides SDN functionality to the device 101. The various actions in method 300 may be performed in the order presented, in a different order or simultaneously. Further, in some embodiments, some actions listed in FIG. 3 may be omitted.



FIG. 4 is a flow diagram which shows various steps involved in the process of analyzing device functionality and designing API module for the device, as disclosed in the embodiments herein. Initially, a any authorized user may trigger (402) the IDE server 102 in the backend to initiate a monitoring, control and management communication with the device 103. The IDE server 102 intercepts (404) all control and management communication with the device 103 and analyzes the intercepted/fetched data for message headers and message contents. For example, the mode of communication may rely on specific protocols such as Command Line Interface (CLI), HTTP, SNMP, and NETCONF and so on for command console based access, for accessing embedded system management process and so on. By analyzing the intercepted messages, the IDE server 102 accesses protocol agents corresponding to each communication associated with the device 103.


After intercepting the messages, the IDE server 102 extracts (406) programmable data elements and value options. In a preferred embodiment, manual trigger to all possible control and command options may be required to ensure proper coverage on discovery of the programmable data elements. In addition to the programmable data elements, the IDE server 102 also extracts (410) information on message rules, validations, error conditions, interdependencies and so on. Further, using the extracted information, the IDE server 102 builds a knowledge base of all scenarios which may be stored in the database 202.e. Further, the data in the database 202.e may be analyzed and inspected to identify various possible message exchanges.


In a preferred embodiment, the analysis and inspection of messages is iterated until data required to build the API model is obtained. The API model is built (408) by considering data such as extracted messaging rules, validations, error conditions, interdependencies and so on. Once the API model is built, compliance of the model with standard rules is to be checked. In a preferred embodiment, the compliance of the model is checked by mapping (414) the created API model with a pre-defined functional, module based and attribute based compliance rule model (416). In a preferred embodiment, the IDE server 102 automatically performs a text matching of attributes and identifies resolved and unresolved attributes. Further, the IDE server 102 may report the unresolved attributes to the user via the frontend 201 and the user may perform a manual mapping for the unresolved ones. Once the mapping is finished, the IDE server 102 checks for compliance of all mapped functions, modules and attributes for which a compliance rule definition exists and level of compliance has been qualified (418). The IDE server 102 also identifies attributes for which compliance could not be achieved and annotates them as a part of an API documentation which in turn may be reported to the IDE frontend 201. Further, the IDE server 102; by using the attributes that are in compliance with the pre configured rules and policies; generates (420) an API model and programmability rules which are refined according to capabilities of the device 103. Various attributes associated with the generated API model is stored as API data model & mapping and information on programmability rules is also maintained as a part of the API data model. The various actions in method 400 may be performed in the order presented, in a different order or simultaneously. Further, in some embodiments, some actions listed in FIG. 4 may be omitted.



FIG. 5 is a flow diagram which shows various steps involved in the process of reviewing API model of a device, as disclosed in the embodiments herein. The API model designed for the device 103 may be checked for compliance with the pre-configured rules and policies by fetching and analyzing API calls related to control and management functions from and to the device 103 via the API module 104. To initiate the review process, at least one unit test developed for the API model under test is executed (502) on the device 103.In a preferred embodiment, the unit test execution may be triggered manually from the IDE client 101 and corresponding calls may get routed via the IDE server 102.


After executing the unit tests, the IDE server 102 intercepts (504) API calls generated as a part of the test case execution and analyze the intercepted calls to identify (508) methods and attributes used in the calls. In a preferred embodiment, the API data model and mapping database comprise information on various attributes associated with the generated API model. Now, a manual trigger is initiated from the IDE client 101 so as to verify results and to perform a compliance check of API calls and rule enforcement. In a preferred embodiment, the IDE server 102 performs a reverse mapping during which equivalent command and control messages that are reversely mapped with a set of APIs are identified by the IDE server 102. A manual check may be required to verify (510) results of the reverse mapping process and results of API calls made during execution of unit tests. After successful completion of the verification process, the IDE server refers the database of programmability and compliance rules (514) so as to identify any associated scenario that can potentially raise a validation, error condition and/or compliance rule enforcement situation for the invoked APIs.


Upon identifying any issue, the IDE server triggers (512) specific unit tests so as to emulate the identified error/validation or enforcement condition. Further, assessment of unit test results may be done on an iterative manner and results may be consolidated (516) to form review records. The review records may be then used as input for further refinement of the API model designed for the device 103. The various actions in method 500 may be performed in the order presented, in a different order or simultaneously. Further, in some embodiments, some actions listed in FIG. 5 may be omitted.



FIGS. 6A and 6B illustrate block diagrams which shows different implementations of the API module in the SDN enablement system, as disclosed in the embodiments herein. FIG. 6 A illustrates an external implementation mode in which the API module 104 is connected external to the device 103. The API Module 104 further comprises of an API Gateway 602 and an API Transform Module 601, which are pre-built components that are independent of device's programmability characteristics. These modules are designed to be reused repetitively for providing support for API enablement for multiple devices 103, while being used in the scope of this engineering environment as defined in the embodiment. During execution, API Gateway 602 accepts the API calls originated from external systems and implements an API call bearing protocol as per the requirements of deployment environment and product owners. The communication protocol used may be any suitable protocol such as RESTful Web Services so as to expose the APIs to the external system. Thus, in the defined architecture, API Gateway 602 accepts the protocol specific communication and transfers the API method calls and attributes to the following layer i.e. the API Transform Module 601. The API Transform Module 601 receives the API call details and matches with its database on API Data Model & Mapping and Programmability Rules, and recognizes the transformation requirements to command syntax and semantics specific to the device 103. The Database on API Data Model & Mapping clarifies which API method call from external system shall be mapped to device specific command & control communication and how the API data attributes will be mapped to device's command & control parameters. Further, the programmability rules database provides clarity on the kind of rules to be enforced on incoming pre-set API calls for policy compliance, validation and error handling purposes. The API Transform module 601 depends on the databases created for the particular device 103 to interoperate with the device 103 in appropriate way. The Protocol peer for monitoring, control & management plane communication component with the device 103 can be standard or custom built, depending on the nature of protocol support available in the device 103. API Transform module 601 passes on the API method and attributes data-structures to this protocol peer for further communication with the other peer hosted in the device 103. The response obtained from the device 103 is then passed on to the API Transform module 601 and response method and attributes are further transformed to API Data Model mapped methods and attributes. Respective programmability rules for the response methods and attributes are enforced before passing on the resultant response to the API Gateway module 602. The API Gateway module 602 then sends back the response to the external system from where the original API call was originated. In another embodiment, the API module 104 may be built as a component of the device 103 as depicted in FIG. 6B. For example, the API module 104 may be embedded as an add-on in the device 103. The preferred deployment model will depend on product's capability to host add-on module, available processing capacity and memory footprints, implementer's and product vendor's preference and commercial agreements.



FIG. 7 illustrates a computing environment implementing the automation of application certification process, according to embodiments as disclosed herein. The computing environment can implement the engineering environment in which the API model is designed and it can also implement the API module 104 wherein the API module may be hosted in an external system in the implementation scenario being considered. As depicted the computing environment 700 comprises at least one processing unit 701 that is equipped with a control unit 701.a and an Arithmetic Logic Unit (ALU) 701.b, a memory 705, a storage unit 704, plurality of networking devices 702 and a plurality Input output (I/O) devices 703. The processing unit 701 is responsible for processing the instructions of the algorithm. The processing unit 701 receives commands from the control unit in order to perform its processing. Further, any logical and arithmetic operations involved in the execution of the instructions are computed with the help of the ALU 701.b.


The overall computing environment 700 can be composed of multiple homogeneous and/or heterogeneous cores, multiple CPUs of different kinds, special media and other accelerators. The processing unit 701 is responsible for processing the instructions of the algorithm. Further, the plurality of processing units 701 may be located on a single chip or over multiple chips. The algorithm comprising of instructions and codes required for the implementation are stored in either the memory unit 705 or the storage 704 or both. At the time of execution, the instructions may be fetched from the corresponding memory 705 and/or storage 704, and executed by the processing unit 701. In case of any hardware implementations various networking devices 702 or external I/O devices 703 may be connected to the computing environment to support the implementation through the networking unit and the I/O device unit.


The embodiments disclosed herein can be implemented through at least one software program running on at least one hardware device and exposing programmable functions to control the elements. The foregoing description of the specific embodiments will so fully reveal the general nature of the embodiments herein that others can, by applying current knowledge, readily modify and/or adapt for various applications such specific embodiments without departing from the generic concept, and, therefore, such adaptations and modifications should and are intended to be comprehended within the meaning and range of equivalents of the disclosed embodiments. It is to be understood that the phraseology or terminology employed herein is for the purpose of description and not of limitation. Therefore, while the embodiments herein have been described in terms of preferred embodiments, those skilled in the art will recognize that the embodiments herein can be practiced with modification within the spirit and scope of the embodiments as described herein.

Claims
  • 1. A method of enabling Application Programming Interface (API) support for a device; said method comprises: leveraging capabilities of said device;designing an API model based on said leveraged device capabilities;reviewing said designed API model; andimplementing said API model on said device.
  • 2. The method as in claim 1, wherein said leveraging capabilities of said device further comprises: initiating at least one of a control, monitoring and management communication between said device and an IDE server;intercepting said initiated communication;fetching at least one of a request, response and notification from said intercepted communication; andanalyzing said fetched request, response and notification.
  • 3. The method as in claim 2, wherein said communication with said device is manually triggered.
  • 4. The method as in claim 2, wherein said communication with said device is automatically triggered.
  • 5. The method as in claim 1, wherein said designing the API model for said device further comprises: extracting at least one of a plurality of programmable data elements and value options from said leveraged device capability information;creating at least one of a validation condition, error condition and interdependency condition and building a knowledge database;recognizing at least one of a plurality of messaging rule, validations, error conditions and interdependency by analyzing said created programmability data elements, value options and knowledge base;checking compliance of a plurality of attributes of said designed API model against a plurality of rules and policies; andrefining said API model based on said compliance check.
  • 6. The method as in claim 1, wherein said reviewing designed API model further comprises: checking compliance of a plurality of attributes of said designed API model against a plurality of rules and policies;qualifying compliance and non compliance of said plurality of attributes based on said compliance check; andrefining said API model based on said qualified attributes.
  • 7. The method as in claim 6, wherein said rules and policies are pre-configured.
  • 8. The method as in claim 6, wherein said compliance check further comprises of reverse mapping commands and controls with a plurality of APIs identified by said IDE server.
  • 9. A system of enabling Application Programming Interface (API) support for a device; said system configured for: leveraging capabilities of said device using an IDE server;designing an API model based on said leveraged device capabilities using said IDE server;reviewing said designed API model using said IDE server; andimplementing said API model on said device using said IDE server.
  • 10. The system as in claim 9, wherein said IDE server is further configured to leverage said capabilities of said device by: initiating at least one of a control, monitoring and management communication between said device and an IDE server using an IDE client;intercepting said initiated communication using an IDE backend;fetching at least one of a request, response and notification from said intercepted communication using said IDE backend; andanalyzing said fetched request, response and notification using said IDE backend.
  • 11. The system as in claim 10, wherein said IDE server further provides means for manually triggering said communication with said device.
  • 12. The system as in claim 10, wherein said IDE server further provides means for automatically triggering said communication with said device
  • 13. The system as in claim 9, wherein said IDE server is further configured to design said API model for said device by: extracting at least one of a plurality of programmable data elements and value options from said leveraged device capability information using an IDE backend;creating at least one of a validation condition, error condition and interdependency condition and building a knowledge database using said IDE backend;recognizing at least one of a plurality of messaging rule, validations, error conditions and interdependency by analyzing said created programmability data elements, value options and knowledge base using said IDE backend;checking compliance of a plurality of attributes of said designed API model against a plurality of rules and policies using said IDE backend; andrefining said API model based on said compliance check using said IDE backend.
  • 14. The system as in claim 9, wherein said IDE server is further configured to review said designed API model by: checking compliance of a plurality of attributes of said designed API model against a plurality of rules and policies using an IDE backend;qualifying compliance and non compliance of said plurality of attributes based on said compliance check using said IDE backend; andrefining said API model based on said qualified attributes using said IDE backend.
  • 15. The system as in claim 14, wherein said IDE server provides means for pre-configuring said rules and policies.
  • 16. The system as in claim 14, wherein said IDE server is further configured to perform said compliance check by reverse mapping commands and controls with a plurality of identified APIs.
  • 17. The system as in claim 9, wherein said system is configured for implementing said API model externally to said device.
  • 18. The system as in claim 9, wherein said system is configured for implementing said API model internally to said device.
Priority Claims (1)
Number Date Country Kind
2671/CHE/2013 Jun 2013 IN national