RFC 6137 - The Network Trouble Ticket Data Model (NTTDM)
Independent Submission D. Zisiadis, Ed. Request for Comments: 6137 S. Kopsidas, Ed. Category: Experimental M. Tsavli, Ed. ISSN: 2070-1721 CERTH G. Cessieux, Ed. CNRS February 2011 The Network Trouble Ticket Data Model (NTTDM) Abstract Handling multiple sets of network trouble tickets (TTs) originating from different participants' inter-connected network environments poses a series of challenges for the involved institutions. A Grid is a good example of such a multi-domain project. Each of the participants follows different procedures for handling trouble in its domain, according to the local technical and linguistic profile. The TT systems of the participants collect, represent, and disseminate TT information in different formats. As a result, management of the daily workload by a central Network Operation Centre (NOC) is a challenge on its own. Normalization of TTs to a common format at the central NOC can ease presentation, storing, and handling of the TTs. In the present document, we provide a model for automating the collection and normalization of the TT received by multiple networks forming the Grid. Each of the participants is using its home TT system within its domain for handling trouble incidents, whereas the central NOC is gathering the tickets in the normalized format for repository and handling. XML is used as the common representation language. The model was defined and used as part of the networking support activity of the EGEE (Enabling Grids for E-sciencE) project. Status of This Memo This document is not an Internet Standards Track specification; it is published for examination, experimental implementation, and evaluation. This document defines an Experimental Protocol for the Internet community. This is a contribution to the RFC Series, independently of any other RFC stream. The RFC Editor has chosen to publish this document at its discretion and makes no statement about its value for implementation or deployment. Documents approved for publication by the RFC Editor are not a candidate for any level of Internet Standard; see Section 2 of RFC 5741. Information about the current status of this document, any errata, and how to provide feedback on it may be obtained at http://www.rfc-editor.org/info/rfc6137. Copyright Notice Copyright (c) 2011 IETF Trust and the persons identified as the document authors. All rights reserved. This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (http://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Table of Contents 1. Introduction ....................................................4 1.1. Terminology ................................................5 1.2. Notations ..................................................6 1.3. About the Network Trouble Ticket Data Model ................6 1.4. About the Network Trouble Ticket Implementation ............7 1.5. Future Plans ...............................................7 2. NTTDM Types and Definitions .....................................7 2.1. Types and Definitions for the TYPE Attribute ...............8 2.1.1. Defined .............................................8 2.1.2. Free ................................................8 2.1.3. Multiple ............................................8 2.1.4. List ................................................8 2.2. Types and Definitions for the VALID FORMAT Attributes ......9 2.2.1. Predefined String ...................................9 2.2.1.1. Definitions of the Predefined Values ......10 2.2.2. String .............................................13 2.2.3. Datetime ...........................................13 3. NTTDM ..........................................................14 3.1. NTTDM Components ..........................................14 3.1.1. NTTDM Attributes ...................................14 3.2. NTTDM Aggregate Classes ...................................15 3.2.1. NTTDM-Document Class ...............................15 3.2.2. Ticket Class .......................................15 3.2.3. Ticket Origin Information ..........................17 3.2.3.1. PARTNER_ID ................................17 3.2.3.2. ORIGINAL_ID ...............................17 3.2.4. Ticket Information .................................17 3.2.4.1. TT_ID .....................................17 3.2.4.2. TT_TITLE ..................................18 3.2.4.3. TT_TYPE ...................................18 3.2.4.4. TT_PRIORITY ...............................18 3.2.4.5. TT_STATUS .................................19 3.2.4.6. TT_SOURCE .................................19 3.2.4.7. TT_OPEN_DATETIME ..........................19 3.2.4.8. TT_CLOSE_DATETIME .........................20 3.2.5. Trouble Details ....................................20 3.2.5.1. TT_SHORT_DESCRIPTION ......................20 3.2.5.2. TT_LONG_DESCRIPTION .......................20 3.2.5.3. TYPE ......................................21 3.2.5.4. TT_IMPACT_ASSESSMENT ......................21 3.2.5.5. START_DATETIME ............................21 3.2.5.6. DETECT_DATETIME ...........................22 3.2.5.7. REPORT_DATETIME ...........................22 3.2.5.8. END_DATETIME ..............................22 3.2.5.9. TT_LAST_UPDATE_TIME .......................23 3.2.5.10. TIME_WINDOW_START ........................23 3.2.5.11. TIME_WINDOW_END ..........................23 3.2.5.12. WORK_PLAN_START_DATETIME .................24 3.2.5.13. WORK_PLAN_END_DATETIME ...................24 3.2.6. Related Data .......................................24 3.2.6.1. RELATED_EXTERNAL_TICKETS ..................24 3.2.6.2. ADDITIONAL_DATA ...........................25 3.2.6.3. RELATED_ACTIVITY ..........................25 3.2.6.4. HISTORY ...................................25 3.2.7. Localization and Impact ............................26 3.2.7.1. AFFECTED_COMMUNITY ........................26 3.2.7.2. AFFECTED_SERVICE ..........................26 3.2.7.3. LOCATION ..................................26 3.2.7.4. NETWORK_NODE ..............................27 3.2.7.5. NETWORK_LINK_CIRCUIT ......................27 3.2.7.6. END_LINE_LOCATION_A .......................27 3.2.7.7. END_LINE_LOCATION_B .......................28 3.2.8. Contact Information ................................28 3.2.8.1. OPEN_ENGINEER .............................28 3.2.8.2. CONTACT_ENGINEERS .........................28 3.2.8.3. CLOSE_ENGINEER ............................29 3.2.9. Security ...........................................29 3.2.9.1. HASH ......................................29 3.3. NTTDM Representation ......................................29 4. Internationalization Issues ....................................31 5. Example ........................................................31 5.1. Link Failure ..............................................31 6. Sample Implementation: XML Schema ..............................32 7. Security Considerations ........................................43 8. IANA Considerations ............................................44 9. Contributors ...................................................44 10. Acknowledgements ..............................................45 11. References ....................................................45 11.1. Normative References .....................................45 11.2. Informative References ...................................45 1. Introduction Problem-impact assessment, reporting, identification, and handling, as well as dissemination of trouble information and delegation of authority, are some of the main tasks that have to be implemented by the members of a Grid in order to successfully manage the network and maintain operational efficiency of the services offered to their users. Different TT systems are used by each network domain, delivering TTs in alternate formats, while the TT load is growing proportionally with network size and serviced users. We hereby define a data model for TT normalization -- the Network Trouble Ticket Data Model (NTTDM) -- initially targeted for network providers serving EGEE [8]. The model is designed in accordance with RFC 1297 [11] and meets requirements of the multiple TT systems used. The NTTDM o is both effective and comprehensive, as it compensates for the core activities of the Network Operation Centres (NOCs). It is also dynamic, allowing additional options to be included in the future, according to demand. o provides an XML representation for conveying incident information across administrative domains between parties that have an operational responsibility of remediation or a "watch-and-warn" policy over a defined constituency. o encodes information about hosts, networks, and the services running on these systems; attack methodology and associated forensic evidence; impact of the activity; and limited approaches for documenting workflow. o aims to simplify TT exchange within the boundaries of a Grid and to enhance the functional cooperation of every NOC and of the Grid Operation Centre (GOC). Community adoption of the NTTDM enhances trouble resolution within the Grid framework and imparts network status cognizance by modeling collaboration and information exchange among operators. o provides a common format that allows GOCs as well as all participating NOCs to store, exchange, manage, and analyze TTs (assessment of TT impact). o provides increased automation in handling a TT, since the network operators have a common view of the incident. The model was designed and used as part of the networking support activity of the EGEE project; one of the subtasks of this support activity was to enhance the ENOC (EGEE Network Operation Centre) [9] procedures for better overall network coordination of the Grid. 1.1. Terminology The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 [1]. The NTTDM uses specific keywords to describe the various data components. These keywords are: Defined, Free, Multiple, List, Predefined String, String, Datetime, Solved, Cancelled, Inactive, Superseded, Opened/Closed, Operational, Informational, Administrative, and Test. These keywords as used in this document are to be interpreted as described in Section 2. Acronyms: TT: Trouble Ticket NTTDM: Network Trouble Ticket Data Model DB: Database EGEE: Enabling Grid for E-sciencE ENOC: EGEE NOC NOC: Network Operation Centre GOC: Grid Operation Centre NREN: National Research and Educational Network QoS: Quality of Service UML: Unified Modeling Language XML: Extensible Markup Language 1.2. Notations The NTTDM is specified in two ways: as an abstract data model and as an XML Schema. Section 3 provides a Unified Modeling Language (UML) [10] model describing the individual classes and their relationship with each other. The semantics of each class are discussed and their attributes explained. In Section 6, this UML model is converted into an XML Schema [2] [3] [4] [5]. A specific namespace [6] is also defined. The term "XML document" refers to any instance of an XML Document. The term "NTTDM document" refers to specific elements and attributes of the NTTDM Schema. Finally, the terms "class" and "element" are used interchangeably to reference either a given UML class in the data model or its corresponding Schema implementation. 1.3. About the Network Trouble Ticket Data Model The NTTDM is a data representation that provides a framework for normalizing and sharing information among network operators and the GOC regarding troubles within the Grid boundaries. There has been a lot of thought processing during the design of the data model: o The data model serves as a common storage and exchange format. o Every NOC still uses its home TT system for network management within its area of control. o As there is no universally adopted definition for a trouble, in the NTTDM definition, the term is used with a comprehensive meaning to cover all NOCs. o Handling every possible definition of a trouble incident would call for an extremely expanded and complex data model. Therefore, the NTTDM's purpose is to serve as the basis for normalizing and exchanging TTs. It is flexible and expressive in order to ensure that specific NOC requirements are met. Specific NOC information is kept outside the NTTDM, and external databases can be used to feed it. o The domain of managing the information is not fully standardized and must rely on free-form textual descriptions. The NTTDM attempts to strike a balance between supporting this free-form content, while still allowing automated processing of incident information. The NTTDM is only one of several feasible TT data representations. The goal of this design was to be as effective and comprehensive as these other representations and to account for the management of a general Grid environment. The already used TT formats influenced the design of the NTTDM. 1.4. About the Network Trouble Ticket Implementation Here we describe an example of a typical use case. The Grid project EGEE manages its infrastructure as a network overlay over the European National Research and Educational Networks (NRENs) and wants to be able to warn EGEE sites of the unavailability of the network. Thanks to collaboration with its network provider, the EGEE NOC receives a high volume of TTs (800 tickets/month, 2500 emails/month) from 20 NRENs and should always be able to cope with such a heavy load. Thanks to the NTTDM, the EGEE NOC can automate the TT workflow: o The TT is filtered, sorted, and stored in a local database (DB). o The TT's impact on the Grid is assessed. o The TT is pushed to an ENOC dashboard application and other tools (EGEE TT system, statistics, etc.). 1.5. Future Plans Since this is an Experimental document, operational experience will be used to expand the subsections of Section 3.2.3, "Ticket Origin Information", below. The current specification is already used within EGEE. Other Grids are free to use it and report comments to the authors. After enough experimentation, we would like to advance it to the Standards Track. 2. NTTDM Types and Definitions The various data elements of the TT data model are typed. This section discusses these data types. When possible, native Schema data types were adopted, but for more complicated formats, regular expressions or external standards were used. 2.1. Types and Definitions for the TYPE Attribute These types are used to describe the TYPE attribute. 2.1.1. Defined The Defined data type means that the data model provides a means to compute this value from the rest of the fields. The Defined data type is implemented as "Defined" in the Schema. 2.1.2. Free The Free data type means that the value can be freely chosen. All Free strings SHOULD have as an attribute the language used. The Free data type is implemented as "Free" in the Schema. 2.1.3. Multiple The Multiple data type consists of one value among multiple fixed values. The Multiple data type is implemented as "Multiple" in the Schema. 2.1.4. List "List" means many values among multiple fixed values. The List data type is implemented as "List" in the Schema. 2.2. Types and Definitions for the VALID FORMAT Attributes 2.2.1. Predefined String A Predefined String means the different values are predefined in the data model. Each field that requires a Predefined String contains a specific value. Figure 1 shows the allowed values for such fields. +------------------------+-----------------------------------+ | FIELD NAME | VALUES | +------------------------+-----------------------------------+ | TT_TYPE | Operational, Informational, | | | Administrative, Test | +------------------------+-----------------------------------+ | TYPE | Scheduled, Unscheduled | +------------------------+-----------------------------------+ | TT_PRIORITY | Low, Medium, High | +------------------------+-----------------------------------+ | TT_SHORT_DESCRIPTION | Core Line Fault, Access Line | | | Fault, Degraded Service, Router | | | Hardware Fault, Router Software | | | Fault, Routing Problem, Undefined | | | Problem, Network Congestion, | | | Client Upgrade, IPv6, QoS, VoIP, | | | Other | +------------------------+-----------------------------------+ | TT_IMPACT_ASSESSMENT | No impact, Reduced redundancy, | | | Minor performance impact, Severe | | | performance impact, | | | No connectivity, On backup, | | | At risk, Unknown | +------------------------+-----------------------------------+ | TT_STATUS | Opened, Updated, Closed, Solved, | | | Inactive, Cancelled, Reopened, | | | Superseded, Opened/Closed | +------------------------+-----------------------------------+ | TT_SOURCE | Users, Monitoring, Other NOC | +------------------------+-----------------------------------+ Figure 1. Allowed Predefined String Values The Predefined String data type is implemented as "xs:string" in the Schema with a sequence of enumerations for the allowed values. 2.2.1.1. Definitions of the Predefined Values TT_TYPE o Operational: for network incident and maintenance only. o Informational: information about the TT system or the exchange interface (maintenance, upgrade). o Administrative: information about the access to the TT system (credentials) or the exchange interface. o Test: to test the TT system or the exchange interface, etc. TYPE o Scheduled: the incident was scheduled to happen. o Unscheduled: the incident was unscheduled. TT_PRIORITY o Low: the TT priority is low. o Medium: the TT priority is medium. o High: the TT priority is high. TT_SHORT_DESCRIPTION o Core Line Fault: malfunction of a high-bandwidth core line. o Access Line Fault: malfunction of a medium-bandwidth access line. o Degraded Service. o Router Hardware Fault: malfunction of the router hardware. o Router Software Fault: malfunction of the router software. o Routing Problem: incident regarding the routing service. o Undefined Problem: nature of the problem not identified. o Network Congestion: problem due to traffic at the network (blocked). o Client Upgrade: incidents regarding client/services upgrade. o IPv6: incident regarding the IPv6 network. o QoS: incident regarding the Quality of Service (QoS) of the network. o VoIP: incident regarding Voice over IP (VoIP). o Other: non-listed incident. TT_IMPACT_ASSESSMENT o No impact: the incident does not cause any impacts. o Reduced redundancy: the incident reduces network redundancy. o Minor performance impact: the incident causes a minor performance impact. o Severe performance impact: the incident causes a severe performance impact. o No connectivity: the incident causes connectivity failure. o On backup: the incident causes a malfunction of backup services. o At risk: the incident should not have any impact but could possibly cause some trouble. o Unknown: the nature of the impact is not identified. TT_STATUS o Opened: the ticket is opened. o Closed: the ticket is closed. o Updated: the ticket's contents have been updated. o Cancelled: the ticket has been opened twice; one of the tickets is cancelled, and a relationship between them is defined via the RELATED_ACTIVITY field. o Solved: the incident is solved, but the team prefers to monitor/check for future issues. o Opened/Closed: the ticket was opened only to report an incident that has already been solved. o Inactive: the ticket is under the responsibility of an external domain and is no longer under the reporting domain's control. o Reopened: the ticket was closed by error, or the problem was erroneously declared to be solved. Data in the History field are very important in this case. o Superseded: the ticket has been superseded by another one (for example, a bigger problem that had resulted in many tickets was later merged into a single incident/ticket). The RELATED_ACTIVITY field SHOULD include the master ticket reference. Allowed transitions for TT_STATUS are only those indicated in Figure 2. Possible final states are indicated with (X). +------------------+ | Opened/Closed (X)| +------------------+ | | V +--------------+ /-----------------------| Reopened |<-------------------\ | | |----------\ | | +--------------+ | | | ^ | | | | | | | V | | | +-------------------+ | | | | Superseded (X) | | | | | or Inactive (X) | | | | /----------------->| or Cancelled (X) |<---\ | | | | +-------------------+ | | | | | ^ | | | | | | | V | | | +--------+ | +--------+ | | | /---------| Opened |----/ | Solved |-----\ | | | | | |---------------->| | | | | | | +--------+ +--------+ | | | | | | ^ | | V | V | | | | +---------+ | | | | | |----------(|)-------------------------/ V V | Updated | | +------------+ | |----------(|)---------------------------->| | +---------+ | | Closed (X) | \----------------------------->| | +------------+ Figure 2. TT_STATUS Transition Diagram 2.2.2. String The String value is defined by the user of the model. The String data type is implemented as "xs:string" in the Schema. 2.2.3. Datetime Date-time strings are represented by the Datetime data type. Each date-time string identifies a particular instant in time; ranges are not supported. Date-time strings are formatted according to a subset of ISO 8601:2000 as documented in RFC 3339. The Datetime data type is implemented as "xs:dateTime" in the Schema. 3. NTTDM In this section, the individual components of the NTTDM will be discussed in detail. This class provides a standardized representation for commonly exchanged Field Name data. 3.1. NTTDM Components 3.1.1. NTTDM Attributes The Field Name class has four attributes. Each attribute provides information about a Field Name instance. The attributes that characterize one instance constitute all the information required to form the data model. DESCRIPTION This field contains a short description of the Field Name. TYPE The TYPE attribute contains information about the type of the Field Name it depends on. The values that it may contain are: Defined, Free, Multiple, and List. VALID FORMAT This attribute contains information about the format of each field. The values that it may contain are: Predefined String, String, and Datetime. MANDATORY This attribute indicates whether the information of each field is required or optional. If the information is required, the MANDATORY field contains the word "YES". If the information is optional, the MANDATORY field contains the word "NO". 3.2. NTTDM Aggregate Classes 3.2.1. NTTDM-Document Class The NTTDM-Document class is the top-level class in the NTTDM. All NTTDM documents are an instance of this class. +---------------+ | NTTDM-Document| +---------------+ | version |<>--{1..*}--[ Ticket ] | lang | +---------------+ Figure 3. NTTDM-Document Class The aggregate class that constitutes an NTTDM-Document is: Ticket One or more. The information related to a single ticket. The NTTDM-Document class has two attributes: version STRING. The value of this attribute MUST be "1.00". lang Required. 3.2.2. Ticket Class Every ticket is represented by an instance of the Ticket class. This class provides a standardized representation for commonly exchanged TT data. +---------+ | Ticket | +---------+ | lang |<>----------[ Partner_ID ] | |<>----------[ Original_ID ] | |<>----------[ TT_ID ] | |<>----------[ TT_Title ] | |<>----------[ TT_Type ] | |<>--{0..1}--[ TT_Priority ] | |<>----------[ TT_Status ] | |<>--{0..1}--[ TT_Source ] | |<>----------[ TT_Open_Datetime ] | |<>----------[ TT_Close_Datetime ] | |<>----------[ TT_Short_Description ] | |<>----------[ TT_Long_Description ] | |<>----------[ Type ] | |<>----------[ TT_Impact_Assessment ] | |<>----------[ Start_Datetime ] | |<>--{0..1}--[ Detect_Datetime ] | |<>--{0..1}--[ Report_Datetime ] | |<>----------[ End_Datetime ] | |<>----------[ TT_Last_Update_Time ] | |<>--{0..1}--[ Time_Window_Start ] | |<>--{0..1}--[ Time_Window_End ] | |<>--{0..1}--[ Work_Plan_Start_Datetime ] | |<>--{0..1}--[ Work_Plan_End_Datetime ] | |<>--{0..1}--[ Related_External_Tickets ] | |<>--{0..1}--[ Additional_Data ] | |<>--{0..1}--[ Related_Activity ] | |<>----------[ History ] | |<>--{0..1}--[ Affected_Community ] | |<>--{0..1}--[ Affected_Service ] | |<>----------[ Location ] | |<>--{0..1}--[ Network_Node ] | |<>--{0..1}--[ Network_Link_Circuit ] | |<>--{0..1}--[ End_Line_Location_A ] | |<>--{0..1}--[ End_Line_Location_B ] | |<>--{0..1}--[ Open_Engineer ] | |<>--{0..1}--[ Contact_Engineers ] | |<>--{0..1}--[ Close_Engineer ] | |<>--{0..1}--[ Hash ] +---------+ Figure 4. The Ticket Class lang Required. The Field Names are the Aggregate Classes that constitute the NTTDM, and each of them is an element that is characterized by a quadruple (DESCRIPTION, TYPE, VALID FORMAT, MANDATORY). 3.2.3. Ticket Origin Information 3.2.3.1. PARTNER_ID +--------------+ | PARTNER_ID | +--------------+ | DESCRIPTION | The unique ID of the TT source partner. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | Yes. +--------------+ Figure 5. Partner_ID Class 3.2.3.2. ORIGINAL_ID +--------------+ | ORIGINAL_ID | +--------------+ | DESCRIPTION | The TT ID that was assigned by the party. | TYPE | Free. | VALID FORMAT | String. | MANDATORY | Yes. +--------------+ Figure 6. Original_ID Class 3.2.4. Ticket Information 3.2.4.1. TT_ID +--------------+ | TT_ID | +--------------+ | DESCRIPTION | The unique ID of the TT. | TYPE | As defined below. | VALID FORMAT | String. | MANDATORY | Yes. +--------------+ Figure 7. TT_ID Class TYPE is constructed as "PARTNER_ID"_"ORIGINAL_ID". PARTNER_ID and ORIGINAL_ID therefore MUST NOT contain an underscore character. 3.2.4.2. TT_TITLE +---------------+ | TT_TITLE | +---------------+ | DESCRIPTION | The title of the TT. | TYPE | Defined. | VALID FORMAT | String. | MANDATORY | Yes. +---------------+ Figure 8. TT_Title Class 3.2.4.3. TT_TYPE +---------------+ | TT_TYPE | +---------------+ | DESCRIPTION | The type of the TT. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | Yes. +---------------+ Figure 9. TT_Type Class 3.2.4.4. TT_PRIORITY +--------------+ | TT_PRIORITY | +--------------+ | DESCRIPTION | The TT priority. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | No. +--------------+ Figure 10. TT_Priority Class 3.2.4.5. TT_STATUS +--------------+ | TT_STATUS | +--------------+ | DESCRIPTION | The TT status. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | Yes. +--------------+ Figure 11. TT_Status Class 3.2.4.6. TT_SOURCE +--------------+ | TT_SOURCE | +--------------+ | DESCRIPTION | The source of the ticket. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | No. +--------------+ Figure 12. TT_Source Class 3.2.4.7. TT_OPEN_DATETIME +------------------+ | TT_OPEN_DATETIME | +------------------+ | DESCRIPTION | The date and time when the TT was opened. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | Yes. +------------------+ Figure 13. TT_Open_Datetime Class 3.2.4.8. TT_CLOSE_DATETIME +-------------------+ | TT_CLOSE_DATETIME | +-------------------+ | DESCRIPTION | The date and time when the TT was closed. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | Yes. +-------------------+ Figure 14. TT_Close_Datetime Class 3.2.5. Trouble Details 3.2.5.1. TT_SHORT_DESCRIPTION +----------------------+ | TT_SHORT_DESCRIPTION | +----------------------+ | DESCRIPTION | The short description of the trouble. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | Yes. +----------------------+ Figure 15. TT_Short_Description Class 3.2.5.2. TT_LONG_DESCRIPTION +---------------------+ | TT_LONG_DESCRIPTION | +---------------------+ | DESCRIPTION | The detailed description of the | | incident/maintenance reported in the TT. | TYPE | Free. | VALID FORMAT | String. | MANDATORY | No. +---------------------+ Figure 16. TT_Long_Description Class 3.2.5.3. TYPE +--------------+ | TYPE | +--------------+ | DESCRIPTION | The type of the trouble. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | Yes. +--------------+ Figure 17. Type Class 3.2.5.4. TT_IMPACT_ASSESSMENT +----------------------+ | TT_IMPACT_ASSESSMENT | +----------------------+ | DESCRIPTION | The impact of the incident/maintenance. | TYPE | Multiple. | VALID FORMAT | Predefined String. | MANDATORY | Yes. +----------------------+ Figure 18. TT_Impact_Assessment Class 3.2.5.5. START_DATETIME +----------------+ | START_DATETIME | +----------------+ | DESCRIPTION | The date and time that the | | incident/maintenance started. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | Yes. +----------------+ Figure 19. Start_Datetime Class 3.2.5.6. DETECT_DATETIME +-------------------+ | DETECT_DATETIME | +-------------------+ | DESCRIPTION | The date and time when the incident | | was detected. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No. +-------------------+ Figure 20. Detect_Datetime Class 3.2.5.7. REPORT_DATETIME +-----------------+ | REPORT_DATETIME | +-----------------+ | DESCRIPTION | The date and time when the incident | | was reported. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No. +-----------------+ Figure 21. Report_Datetime Class 3.2.5.8. END_DATETIME +--------------+ | END_DATETIME | +--------------+ | DESCRIPTION | The date and time when the incident/maintenance | | ended. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | Yes. +--------------+ Figure 22. End_Datetime Class 3.2.5.9. TT_LAST_UPDATE_TIME +---------------------+ | TT_LAST_UPDATE_TIME | +---------------------+ | DESCRIPTION | The last date and time when the TT was | | updated. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | Yes. +---------------------+ Figure 23. TT_Last_Update_Time Class 3.2.5.10. TIME_WINDOW_START +-------------------+ | TIME_WINDOW_START | +-------------------+ | DESCRIPTION | The window start time in which planned | | maintenance may occur. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No, unless TYPE is "Scheduled". +-------------------+ Figure 24. Time_Window_Start Class 3.2.5.11. TIME_WINDOW_END +-----------------+ | TIME_WINDOW_END | +-----------------+ | DESCRIPTION | The window end time in which planned | | maintenance may occur. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No, unless TYPE is "Scheduled". +-----------------+ Figure 25. Time_Window_End Class 3.2.5.12. WORK_PLAN_START_DATETIME +--------------------------+ | WORK_PLAN_START_DATETIME | +--------------------------+ | DESCRIPTION | Work planned (expected): start time | | in case of maintenance. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No. +--------------------------+ Figure 26. Work_Plan_Start_Datetime Class 3.2.5.13. WORK_PLAN_END_DATETIME +------------------------+ | WORK_PLAN_END_DATETIME | +------------------------+ | DESCRIPTION | Work planned (expected): end time | | in case of maintenance. | TYPE | Multiple. | VALID FORMAT | Datetime. | MANDATORY | No. +------------------------+ Figure 27. Work_Plan_End_Datetime Class The period delimited by WORK_PLAN_START_DATETIME and WORK_PLAN_END_DATETIME MUST be included in the period delimited by TIME_WINDOW_START and TIME_WINDOW_END, and duplicated with {START, END}_DATETIME, even in case of maintenance. 3.2.6. Related Data 3.2.6.1. RELATED_EXTERNAL_TICKETS +--------------------------+ | RELATED_EXTERNAL_TICKETS | +--------------------------+ | DESCRIPTION | The NOC entity related to the incident. | TYPE | List. | VALID FORMAT | String. | MANDATORY | No. +--------------------------+ Figure 28. Related_External_Tickets Class 3.2.6.2. ADDITIONAL_DATA +-----------------+ | ADDITIONAL_DATA | +-----------------+ | DESCRIPTION | Additional information. | TYPE | Free. | VALID FORMAT | String. | MANDATORY | No. +-----------------+ Figure 29. Additional_Data Class 3.2.6.3. RELATED_ACTIVITY +------------------+ | RELATED_ACTIVITY | +------------------+ | DESCRIPTION | The TT IDs of the related incidents. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +------------------+ Figure 30. Related_Activity Class 3.2.6.4. HISTORY +--------------+ | HISTORY | +--------------+ | DESCRIPTION | The necessary actions/events log. | TYPE | Free. | VALID FORMAT | String. | MANDATORY | Yes. +--------------+ Figure 31. History Class Note: This field MUST NOT be empty when the VALID FORMAT attribute of the TT_STATUS field is anything other than "OPENED" or "OPENED/CLOSED". 3.2.7. Localization and Impact 3.2.7.1. AFFECTED_COMMUNITY +--------------------+ | AFFECTED_COMMUNITY | +--------------------+ | DESCRIPTION | Information about the community that was | | affected by the incident. | TYPE | Free. | VALID FORMAT | String. | MANDATORY | No. +--------------------+ Figure 32. Affected_Community Class 3.2.7.2. AFFECTED_SERVICE +------------------+ | AFFECTED_SERVICE | +------------------+ | DESCRIPTION | The service that was affected by the | | incident. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +------------------+ Figure 33. Affected_Service Class 3.2.7.3. LOCATION +--------------+ | LOCATION | +--------------+ | DESCRIPTION | The location (Point of Presence (POP) site, | | city, etc.) of the incident/maintenance. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | Yes. +--------------+ Figure 34. Location Class 3.2.7.4. NETWORK_NODE +--------------+ | NETWORK_NODE | +--------------+ | DESCRIPTION | The NOC network node related to the incident. | TYPE | List. | VALID FORMAT | String. | MANDATORY | No. +--------------+ Figure 35. Network_Node Class 3.2.7.5. NETWORK_LINK_CIRCUIT +----------------------+ | NETWORK_LINK_CIRCUIT | +----------------------+ | DESCRIPTION | The name of the network line related | | to the incident. | TYPE | List. | VALID FORMAT | String. | MANDATORY | No. +----------------------+ Figure 36. Network_Link_Circuit Class 3.2.7.6. END_LINE_LOCATION_A +---------------------+ | END_LINE_LOCATION_A | +---------------------+ | DESCRIPTION | A-end of the link. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +---------------------+ Figure 37. End_Line_Location_A Class 3.2.7.7. END_LINE_LOCATION_B +---------------------+ | END_LINE_LOCATION_B | +---------------------+ | DESCRIPTION | B-end of the link. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +---------------------+ Figure 38. End_Line_Location_B Class 3.2.8. Contact Information 3.2.8.1. OPEN_ENGINEER +---------------+ | OPEN_ENGINEER | +---------------+ | DESCRIPTION | The engineer that opened the ticket. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +---------------+ Figure 39. Open_Engineer Class 3.2.8.2. CONTACT_ENGINEERS +-------------------+ | CONTACT_ENGINEERS | +-------------------+ | DESCRIPTION | The engineers responsible for the incident | | settlement. | TYPE | List. | VALID FORMAT | String. | MANDATORY | No. +-------------------+ Figure 40. Contact_Engineers Class 3.2.8.3. CLOSE_ENGINEER +----------------+ | CLOSE_ENGINEER | +----------------+ | DESCRIPTION | The engineer that closed the ticket. | TYPE | Multiple. | VALID FORMAT | String. | MANDATORY | No. +----------------+ Figure 41. Close_Engineer Class 3.2.9. Security 3.2.9.1. HASH +-------------+ | HASH | +-------------+ | DESCRIPTION | Encrypted message hash. | TYPE | Defined. | VALID FORMAT| String. | MANDATORY | No. +-------------+ Figure 42. Hash Class 3.3. NTTDM Representation The collected and processed TTs received from multiple telecommunications networks are adjusted in a normalized NTTDM. Figure 43 shows the representation of this normalized data model. The "DESCRIPTION" attribute is implied. +------------------------+--------+------------------+---------+ | FIELD NAME | TYPE |VALID FORMAT |MANDATORY| +------------------------+--------+------------------+---------+ |PARTNER_ID |MULTIPLE|STRING |YES | |ORIGINAL_ID |FREE |STRING |YES | |TT_ID |DEFINED |STRING |YES | |TT_TITLE |DEFINED |STRING |YES | |TT_TYPE |MULTIPLE|PREDEFINED STRING |YES | |TT_PRIORITY |MULTIPLE|PREDEFINED STRING |NO | |TT_STATUS |MULTIPLE|PREDEFINED STRING |YES | |TT_SOURCE |MULTIPLE|PREDEFINED STRING |NO | |TT_OPEN_DATETIME |MULTIPLE|DATETIME |YES | |TT_CLOSE_DATETIME |MULTIPLE|DATETIME |YES | |TT_SHORT_DESCRIPTION |MULTIPLE|PREDEFINED STRING |YES | |TT_LONG_DESCRIPTION |FREE |STRING |NO | |TYPE |MULTIPLE|PREDEFINED STRING |YES | |TT_IMPACT_ASSESSMENT |MULTIPLE|PREDEFINED STRING |YES | |START_DATETIME |MULTIPLE|DATETIME |YES | |DETECT_DATETIME |MULTIPLE|DATETIME |NO | |REPORT_DATETIME |MULTIPLE|DATETIME |NO | |END_DATETIME |MULTIPLE|DATETIME |YES | |TT_LAST_UPDATE_TIME |MULTIPLE|DATETIME |YES | |TIME_WINDOW_START |MULTIPLE|DATETIME |NO | |TIME_WINDOW_END |MULTIPLE|DATETIME |NO | |WORK_PLAN_START_DATETIME|MULTIPLE|DATETIME |NO | |WORK_PLAN_END_DATETIME |MULTIPLE|DATETIME |NO | |RELATED_EXTERNAL_TICKETS|LIST |STRING |NO | |ADDITIONAL_DATA |FREE |STRING |NO | |RELATED_ACTIVITY |MULTIPLE|STRING |NO | |HISTORY |FREE |STRING |YES | |AFFECTED_COMMUNITY |FREE |STRING |NO | |AFFECTED_SERVICE |MULTIPLE|STRING |NO | |LOCATION |MULTIPLE|STRING |YES | |NETWORK_NODE |LIST |STRING |NO | |NETWORK_LINK_CIRCUIT |LIST |STRING |NO | |END_LINE_LOCATION_A |MULTIPLE|STRING |NO | |END_LINE_LOCATION_B |MULTIPLE|STRING |NO | |OPEN_ENGINEER |MULTIPLE|STRING |NO | |CONTACT_ENGINEERS |LIST |STRING |NO | |CLOSE_ENGINEER |MULTIPLE|STRING |NO | |HASH |DEFINED |STRING |NO | +------------------------+--------+------------------+---------+ Figure 43. The Field Name Class 4. Internationalization Issues Internationalization and localization are of specific concern to the NTTDM, since it is only through collaboration, often across language barriers, that certain incidents can be resolved. The NTTDM supports this goal by depending on XML constructs, and through explicit design choices in the data model. The main advantage of the model is that it provides a normalized data type that is implemented fully in the English language and can be used conveniently. It also supports free-formed text that can be written in any language. In the future, it will provide translation services for all such free-formed text. 5. Example 5.1. Link Failure In this section, an example of network TTs exchanged using the proposed format is provided. This is an actual GRNet ticket normalized according to the NTTDM. Fields that were not included in the ticket are left blank. <?xml version="1.0" encoding="UTF-8"?> <!-- This example describes a link failure that was detected --> <NTTDM-Document version="1.00" lang="el" xmlns="urn:ietf:params:xml:ns:nttdm-1.0"> <Ticket> <Original_ID>5985</Original_ID> <Partner_ID>01</Partner_ID> <TT_ID>01_5985</TT_ID> <TT_Title>Forth Link Failure</TT_Title> <TT_Type>Operational</TT_Type> <TT_Status>Closed</TT_Status> <TT_Open_Datetime>2008-12-16T10:01:15+02:00</TT_Open_Datetime> <TT_Short_Description>Core Line Fault</TT_Short_Description> <TT_Long_Description>Forth Link Failure</TT_Long_Description> <Type>Unscheduled</Type> <TT_Impact_Assessment>No connectivity</TT_Impact_Assessment> <Start_Datetime>2008-12-16T09:55:00+02:00</Start_Datetime> <TT_Last_Update_Time>2008-12-16T15:00:34+02:00</TT_Last_Update_Time> <Location>HERAKLION</Location> <History>Optical transmitter was changed</History> <TT_Close_Datetime>2008-12-16T15:05:00+02:00</TT_Close_Datetime> <End_Datetime>2008-12-16T15:01:21+02:00</End_Datetime> <Network_Node> <Node>FORTH</Node> </Network_Node> <Network_Link_Circuit> <Link_Circuit>FORTH-2</Link_Circuit> </Network_Link_Circuit> <Open_Engineer>Dimitris Zisiadis</Open_Engineer> <Close_Engineer>Guillaume Cessieux</Close_Engineer> <Contact_Engineers> <Engineer>Spyros Kopsidas</Engineer> <Engineer>Chrysostomos Tziouvaras</Engineer> </Contact_Engineers> <TT_Priority>High</TT_Priority> </Ticket> </NTTDM-Document> 6. Sample Implementation: XML Schema This section provides a sample XML Schema of the NTTDM. <?xml version="1.0" encoding="UTF-8" ?> <xs:schema xmlns="urn:ietf:params:xml:ns:nttdm-0.1" xmlns:nttdm="urn:ietf:params:xml:ns:nttdm-1.0" xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="urn:ietf:params:xml:ns:nttdm-1.0" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:annotation> <xs:documentation >Trouble Ticket Data Model v-1.0</xs:documentation> </xs:annotation> <!-- =============================================================== == NTTDM-Document Class == =============================================================== --> <xs:element name="NTTDM-Document"> <xs:complexType> <xs:sequence> <xs:element ref="nttdm:Ticket" maxOccurs="unbounded"/> </xs:sequence> <xs:attribute name="version" type="xs:string" fixed="1.00"/> <xs:attribute name="lang" type="xs:language" use="required"/> </xs:complexType> </xs:element> <!-- =============================================================== == Ticket Class == =============================================================== --> <xs:element name="Ticket"> <xs:complexType> <xs:all> <xs:element ref="nttdm:Partner_ID"/> <xs:element ref="nttdm:Original_ID"/> <xs:element ref="nttdm:TT_ID"/> <xs:element ref="nttdm:TT_Title"/> <xs:element ref="nttdm:TT_Type"/> <xs:element ref="nttdm:TT_Priority" minOccurs="0"/> <xs:element ref="nttdm:TT_Status"/> <xs:element ref="nttdm:TT_Source" minOccurs="0"/> <xs:element ref="nttdm:TT_Open_Datetime"/> <xs:element ref="nttdm:TT_Close_Datetime"/> <xs:element ref="nttdm:TT_Short_Description"/> <xs:element ref="nttdm:TT_Long_Description"/> <xs:element ref="nttdm:Type"/> <xs:element ref="nttdm:TT_Impact_Assessment"/> <xs:element ref="nttdm:Start_Datetime"/> <xs:element ref="nttdm:Detect_Datetime" minOccurs="0"/> <xs:element ref="nttdm:Report_Datetime" minOccurs="0"/> <xs:element ref="nttdm:End_Datetime"/> <xs:element ref="nttdm:TT_Last_Update_Time"/> <xs:element ref="nttdm:Time_Window_Start" minOccurs="0"/> <xs:element ref="nttdm:Time_Window_End" minOccurs="0"/> <xs:element ref="nttdm:Work_Plan_Start_Datetime" minOccurs="0"/> <xs:element ref="nttdm:Work_Plan_End_Datetime" minOccurs="0"/> <xs:element ref="nttdm:Related_External_Tickets" minOccurs="0"/> <xs:element ref="nttdm:Additional_Data" minOccurs="0"/> <xs:element ref="nttdm:Related_Activity" minOccurs="0"/> <xs:element ref="nttdm:History"/> <xs:element ref="nttdm:Affected_Community" minOccurs="0"/> <xs:element ref="nttdm:Affected_Service" minOccurs="0"/> <xs:element ref="nttdm:Location"/> <xs:element ref="nttdm:Network_Node" minOccurs="0"/> <xs:element ref="nttdm:Network_Link_Circuit" minOccurs="0"/> <xs:element ref="nttdm:End_Line_Location_B" minOccurs="0"/> <xs:element ref="nttdm:Open_Engineer" minOccurs="0"/> <xs:element ref="nttdm:Contact_Engineers" minOccurs="0"/> <xs:element ref="nttdm:Close_Engineer" minOccurs="0"/> <xs:element ref="nttdm:Hash" minOccurs="0"/> <xs:element ref="nttdm:End_Line_Location_A" minOccurs="0"/> </xs:all> <xs:attribute name="lang" type="xs:language"/> </xs:complexType> </xs:element> <!-- =============================================================== == Partner_ID Class == =============================================================== --> <xs:element name="Partner_ID" type="nttdm:string_no_underscore"/> <!-- =============================================================== == Original_ID Class == =============================================================== --> <xs:element name="Original_ID" type="nttdm:string_no_underscore"/> <!-- =============================================================== == TT_ID Class == =============================================================== --> <xs:element name="TT_ID" type="xs:string"/> <!-- =============================================================== == TT_Title Class == =============================================================== --> <xs:element name="TT_Title" type="xs:string"/> <!-- =============================================================== == TT_Type Class == =============================================================== --> <xs:element name="TT_Type" type="nttdm:eTT_Type"/> <!-- =============================================================== == TT_Priority Class == =============================================================== --> <xs:element name="TT_Priority" type="nttdm:eTT_Priority"/> <!-- =============================================================== == TT_Status Class == =============================================================== --> <xs:element name="TT_Status" type="nttdm:eTT_Status"/> <!-- =============================================================== == TT_Source Class == =============================================================== --> <xs:element name="TT_Source" type="nttdm:eTT_Source"/> <!-- =============================================================== == TT_Open_Datetime Class == =============================================================== --> <xs:element name="TT_Open_Datetime" type="xs:dateTime"/> <!-- =============================================================== == TT_Close_Datetime Class == =============================================================== --> <xs:element name="TT_Close_Datetime" type="xs:dateTime"/> <!-- =============================================================== == TT_Short_Description Class == =============================================================== --> <xs:element name="TT_Short_Description" type="nttdm:eTT_Short_Description"/> <!-- =============================================================== == TT_Long_Description Class == =============================================================== --> <xs:element name="TT_Long_Description" type="xs:string"/> <!-- =============================================================== == Type Class == =============================================================== --> <xs:element name="Type" type="nttdm:eType"/> <!-- =============================================================== == TT_Impact_Assessment Class == =============================================================== --> <xs:element name="TT_Impact_Assessment" type="nttdm:eTT_Impact_Assessment"/> <!-- =============================================================== == Start_Datetime Class == =============================================================== --> <xs:element name="Start_Datetime" type="xs:dateTime"/> <!-- =============================================================== == Detect_Datetime Class == =============================================================== --> <xs:element name="Detect_Datetime" type="xs:dateTime"/> <!-- =============================================================== == Report_Datetime Class == =============================================================== --> <xs:element name="Report_Datetime" type="xs:dateTime"/> <!-- =============================================================== == End_Datetime Class == =============================================================== --> <xs:element name="End_Datetime" type="xs:dateTime"/> <!-- =============================================================== == TT_Last_Update_Time Class == =============================================================== --> <xs:element name="TT_Last_Update_Time" type="xs:dateTime"/> <!-- =============================================================== == Time_Window_Start Class == =============================================================== --> <xs:element name="Time_Window_Start" type="xs:dateTime"/> <!-- =============================================================== == Time_Window_End Class == =============================================================== --> <xs:element name="Time_Window_End" type="xs:dateTime"/> <!-- =============================================================== == Work_Plan_Start_Datetime Class == =============================================================== --> <xs:element name="Work_Plan_Start_Datetime" type="xs:dateTime"/> <!-- =============================================================== == Work_Plan_End_Datetime Class == =============================================================== --> <xs:element name="Work_Plan_End_Datetime" type="xs:dateTime"/> <!-- =============================================================== == Related_External_Tickets Class == =============================================================== --> <xs:element name="Related_External_Tickets" type="nttdm:eRelated_External_Tickets"/> <!-- =============================================================== == Additional_Data Class == =============================================================== --> <xs:element name="Additional_Data" type="xs:string"/> <!-- =============================================================== == Related_Activity Class == =============================================================== --> <xs:element name="Related_Activity" type="nttdm:eRelated_Activity"/> <!-- =============================================================== == History Class == =============================================================== --> <xs:element name="History" type="xs:string"/> <!-- =============================================================== == Affected_Community Class == =============================================================== --> <xs:element name="Affected_Community" type="xs:string"/> <!-- =============================================================== == Affected_Service Class == =============================================================== --> <xs:element name="Affected_Service" type="xs:string"/> <!-- =============================================================== == Location Class == =============================================================== --> <xs:element name="Location" type="xs:string"/> <!-- =============================================================== == Network_Node Class == =============================================================== --> <xs:element name="Network_Node" type="nttdm:eNodes"/> <!-- =============================================================== == Network_Link_Circuit Class == =============================================================== --> <xs:element name="Network_Link_Circuit" type="nttdm:eNetwork_Link_Circuit"/> <!-- =============================================================== == End_Line_Location_A Class == =============================================================== --> <xs:element name="End_Line_Location_A" type="xs:string"/> <!-- =============================================================== == End_Line_Location_B Class == =============================================================== --> <xs:element name="End_Line_Location_B" type="xs:string"/> <!-- =============================================================== == Open_Engineer Class == =============================================================== --> <xs:element name="Open_Engineer" type="xs:string"/> <!-- =============================================================== == Contact_Engineers Class == =============================================================== --> <xs:element name="Contact_Engineers" type="nttdm:eEngineers"/> <!-- =============================================================== == Close_Engineer Class == =============================================================== --> <xs:element name="Close_Engineer" type="xs:string"/> <!-- =============================================================== == Hash Class == =============================================================== --> <xs:element name="Hash" type="xs:string"/> <!-- =============================================================== == Custom types definition == =============================================================== --> <xs:simpleType name="string_no_underscore"> <xs:restriction base="xs:string"> <xs:pattern value="[^_]*"/> </xs:restriction> </xs:simpleType> <xs:complexType name="eRelated_External_Tickets"> <xs:sequence> <xs:element name="TTid" type="xs:string" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:complexType name="eRelated_Activity"> <xs:sequence> <xs:element name="TT" type="xs:string" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:complexType name="eNodes"> <xs:sequence> <xs:element name="Node" type="xs:string" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:complexType name="eNetwork_Link_Circuit"> <xs:sequence> <xs:element name="Link_Circuit" type="xs:string" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:complexType name="eEngineers"> <xs:sequence> <xs:element name="Engineer" type="xs:string" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:simpleType name="eTT_Type"> <xs:restriction base="xs:string"> <xs:enumeration value="Operational"/> <xs:enumeration value="Informational"/> <xs:enumeration value="Administrative"/> <xs:enumeration value="Test"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eType"> <xs:restriction base="xs:string"> <xs:enumeration value="Scheduled"/> <xs:enumeration value="Unscheduled"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eTT_Priority"> <xs:restriction base="xs:string"> <xs:enumeration value="Low"/> <xs:enumeration value="Medium"/> <xs:enumeration value="High"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eTT_Short_Description"> <xs:restriction base="xs:string"> <xs:enumeration value="Core Line Fault"/> <xs:enumeration value="Access Line Fault"/> <xs:enumeration value="Degraded Service"/> <xs:enumeration value="Router Hardware Fault"/> <xs:enumeration value="Router Software Fault"/> <xs:enumeration value="Routing Problem"/> <xs:enumeration value="Undefined Problem"/> <xs:enumeration value="Network Congestion"/> <xs:enumeration value="Client Upgrade"/> <xs:enumeration value="IPv6"/> <xs:enumeration value="QoS"/> <xs:enumeration value="VoIP"/> <xs:enumeration value="Other"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eTT_Impact_Assessment"> <xs:restriction base="xs:string"> <xs:enumeration value="No impact"/> <xs:enumeration value="Reduced redundancy"/> <xs:enumeration value="Minor performance impact"/> <xs:enumeration value="Severe performance impact"/> <xs:enumeration value="No connectivity"/> <xs:enumeration value="On backup"/> <xs:enumeration value="At risk"/> <xs:enumeration value="Unknown"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eTT_Status"> <xs:restriction base="xs:string"> <xs:enumeration value="Opened"/> <xs:enumeration value="Updated"/> <xs:enumeration value="Closed"/> <xs:enumeration value="Solved"/> <xs:enumeration value="Opened/Closed"/> <xs:enumeration value="Inactive"/> <xs:enumeration value="Cancelled"/> <xs:enumeration value="Reopened"/> <xs:enumeration value="Superseded"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="eTT_Source"> <xs:restriction base="xs:string"> <xs:enumeration value="Users"/> <xs:enumeration value="Monitoring"/> <xs:enumeration value="Other NOC"/> </xs:restriction> </xs:simpleType> </xs:schema> 7. Security Considerations The NTTDM data model defines a data model and the relevant XML Schema for trouble ticket normalization; as such, the NTTDM itself does not raise any security concerns. However, some security issues SHOULD be considered as network TTs could carry sensitive information (IP addresses, contact details, authentication details, commercial providers involved, etc.) about flagship institutions (military, health centre...). The security considerations MAY involve measures during the exchange as well as during processing of the information. The HASH field is intended to provide an integrity insurance attribute within the exchanged tickets; however, it alone does not ensure integrity. Confidentiality MAY be ensured by encrypting whole tickets or only some parts of them. This could permit meaningful tickets to be disclosed, while only sensitive information would be protected. Peer entity authentication SHOULD be provided in order to establish a session with data origin authentication, regardless of the form in which the TTs are exchanged -- being delivered either through email, web forms, or through a Simple Object Access Protocol (SOAP) service. SOAP is considered the better choice; the model itself, though, does not specify the communications requirements. The underlying communications service MUST provide guarantees to properly address integrity, confidentiality, and peer entity authentication. The selection of the enforcing mechanisms is not in the scope of this document, and the choice is up to the implementers. For data processing security, each participating organization MAY use its own privacy policy, as part of its own data processing system. This approach avoids any interoperability issues and does not pose any extra burden for the adoption of the current scheme into the operational procedures of the NOCs. Unauthorized and inappropriate usage MUST be avoided. 8. IANA Considerations This document uses URNs to describe an XML namespace and Schema conforming to a registry mechanism described in [7]. Registration for the NTTDM namespace: o URI: urn:ietf:params:xml:ns:nttdm-1.0 o Registrant Contact: See the first author listed in the "Authors' Addresses" section of this document. o XML: None. Namespace URIs do not represent an XML specification. Registration for the NTTDM XML Schema: o URI: urn:ietf:params:xml:schema:nttdm-1.0 o Registrant Contact: See the first author listed in the "Authors' Addresses" section of this document. o XML: See the XML Schema in Section 6 of this document. 9. Contributors Leandros Tassiulas Centre for Research and Technology Hellas 6th km Thermi-Thessaloniki, 57001 Hellas EMail: leandros@uth.gr Chrysostomos Tziouvaras Greek Research and Technology Network 56, Mesogion Av. 11527, Athens Hellas EMail: tziou@grnet.gr Xavier Jeannin National Centre for Scientific Research Network Unit - UREC France EMail: Xavier.Jeannin@urec.cnrs.fr 10. Acknowledgements The following groups and individuals contributed substantially to this document and are gratefully acknowledged: - Toby Rodwell and Emma Apted (DANTE) - Claudio Allocchio, Gloria Vuagnin, and Claudia Battista (GARR) - Karin Schauerhammer and Robert Stoy (DFN) 11. References 11.1. Normative References [1] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997. [2] World Wide Web Consortium, "Extensible Markup Language (XML) 1.0 (Fifth Edition)", W3C Recommendation, 26 November 2008, <http://www.w3.org/TR/2008/REC-xml-20081126>. [3] World Wide Web Consortium, "XML Schema Part 0: Primer Second Edition", W3C Recommendation, 28 October 2004, <http://www.w3.org/TR/2004/REC-xmlschema-0-20041028/>. [4] World Wide Web Consortium, "XML Schema Part 1: Structures Second Edition", W3C Recommendation, 28 October 2004, <http://www.w3.org/TR/xmlschema-1/>. [5] World Wide Web Consortium, "XML Schema Part 2: Datatypes Second Edition", W3C Recommendation, 28 October 2004, <http://www.w3.org/TR/xmlschema-2/>. [6] World Wide Web Consortium, "Namespaces in XML 1.0 (Third Edition)", W3C Recommendation, 8 December 2009, <http://www.w3.org/TR/2009/REC-xml-names-20091208/>. [7] Mealling, M., "The IETF XML Registry", BCP 81, RFC 3688, January 2004. 11.2. Informative References [8] Enabling Grids for E-sciencE, http://www.eu-egee.org/. [9] Enabling Grids for E-sciencE, "ENOC, EGEE Network Operation Centre", http://technical.eu-egee.org/index.php?id=353. [10] Rumbaugh, J., Jacobson, I., and G. Booch, "The Unified Modeling Language Reference Manual," ISBN 020130998X, Addison-Wesley, 1998. [11] Johnson, D., "NOC Internal Integrated Trouble Ticket System Functional Specification Wishlist ("NOC TT REQUIREMENTS")", RFC 1297, January 1992. Authors' Addresses Dimitris Zisiadis (editor) Centre for Research and Technology Hellas 6th km Thermi-Thessaloniki, 57001 Hellas EMail: dzisiadis@iti.gr Spyros Kopsidas (editor) Centre for Research and Technology Hellas 6th km Thermi-Thessaloniki, 57001 Hellas EMail: spyros@uth.gr Matina Tsavli (editor) Centre for Research and Technology Hellas 6th km Thermi-Thessaloniki, 57001 Hellas EMail: sttsavli@uth.gr Guillaume Cessieux (editor) Computer Centre of National Institute for Nuclear Physics and Particle Physics (IN2P3-CC) France EMail: Guillaume.Cessieux@cc.in2p3.fr User Contributions:
|
Comment about this RFC, ask questions, or add new information about this topic: