Cláusula SYNTAX

A macro OBJECT-TYPE contém uma cláusula SYNTAX que define os dados e o tipo para o objeto MIB. Embora o Provedor SNMP observe regras gerais para mapear cláusulas SYNTAX, o provedor também segue regras específicas para vários tipos de dados.

Observação

Para obter mais informações sobre como instalar o provedor, confira Como configurar o ambiente SNMP do WMI.

As seguintes regras de mapeamento se aplicam a todos os tipos de dados descritos na tabela abaixo:

  • A representação textual da cláusula SYNTAX é mapeada para o qualificador de propriedade CIM textual_convention.
  • A definição de tipo nomeado na cláusula SYNTAX é mapeada para o qualificador de propriedade CIM object_syntax. Esse mapeamento é diferente dependendo do tipo de dados. Para obter mais informações, confira as Descrições de mapeamento.
  • O tipo SNMP usado ao codificar quadros de protocolo SNMPv1 e SNMPv2C é mapeado para o qualificador de propriedade CIM encoding.
  • O qualificador de propriedade CIM cimtype contém a representação textual que formata o valor do protocolo CIM subjacente.

A tabela a seguir lista os tipos de dados que têm regras específicas que regem o comportamento de mapeamento do provedor.

Tipo de dados SNMP Descrição
Tipo primitivo Um dos tipos de dados básicos definidos nos documentos da SMI (Estrutura de Informações de Gerenciamento) RFC 1213 e RFC 1903.
Convenção textual Definição de tipo gerada por meio do uso explícito da macro TEXTUAL-CONVENTION SNMPv2C ou gerada por meio do uso de um tipo nomeado. A convenção textual atribui um nome e, em alguns casos, um intervalo de valores a um tipo de dado existente.
Tipo nomeado Referência nomeada a um tipo primitivo, convenção textual ou tipo restrito.
Tipo restrito Tipo primitivo, tipo nomeado ou convenção textual que foi restringido por algum mecanismo de subtipagem definido nos documentos SMI RFC 1213 e RFC 1903.

Tipo Primitivo

O tipo primitivo é um dos tipos de dados básicos definidos nos documentos da SMI (Estrutura de Informações de Gerenciamento) RFC 1213 e RFC 1903. Os tipos primitivos SNMP são mapeados para os tipos definidos por CIM. A tabela a seguir lista o mapeamento que ocorre quando a cláusula SYNTAX se refere explicitamente a um tipo primitivo para SNMPv1. Os qualificadores textual_convention, encoding e object_syntax são sempre iguais ao tipo MIB e o valor padrão é sempre NULL.

Tipo MIB Tipo de variante do CIM Valor cimtype
INTEGER VT_I4 sint32
OCTETSTRING VT_BSTR cadeia de caracteres
OBJECTIDENTIFIER VT_BSTR cadeia de caracteres
NULO VT_NULL Sem suporte
IpAddress VT_BSTR cadeia de caracteres
Contador VT_I4 uint32
Medidor VT_I4 uint32
TimeTicks VT_I4 uint32
Opaco VT_BSTR cadeia de caracteres
NetworkAddress VT_BSTR cadeia de caracteres

O provedor ignora a macro OBJECT-TYPE quando a cláusula SYNTAX se refere a NULL, explicitamente ou por meio de uma atribuição de tipo nomeado. A tabela a seguir lista o mapeamento que ocorre quando a cláusula SYNTAX se refere explicitamente a um tipo primitivo para SNMPv2. Os qualificadores textual_convention, encoding e object_syntax são sempre iguais ao tipo MIB e o valor padrão é sempre NULL.

Tipo MIB Tipo de variante do CIM Valor cimtype
INTEGER VT_I4 sint32
OCTET STRING VT_BSTR cadeia de caracteres
OBJECT IDENTIFIER VT_BSTR cadeia de caracteres
IpAddress VT_BSTR cadeia de caracteres
Counter32 VT_I4 uint32
Gauge32 VT_I4 uint32
Unsigned32 VT_I4 uint32
Integer32 VT_I4 sint32
Counter64 VT_BSTR uint64
TimeTicks VT_I4 uint32
Opaco VT_BSTR cadeia de caracteres

Tipo Nomeado

Os tipos nomeados SNMP são mapeados para os tipos definidos por CIM. Quando a cláusula SYNTAX se referis a um tipo primitivo, convenção textual ou tipo restrito por meio de uma derivação de atribuição de tipo, use esses tipos para determinar quais procedimentos de mapeamento são aplicáveis.

  • Se, por meio da derivação das regras de atribuição de tipo, você encontrar uma definição de tipo restrito:

    • E se, por meio de derivação adicional, você encontrar uma das convenções textuais listadas na Macro TEXTUAL-CONVENTION, aplique as regras de mapeamento para tipos restritos e convenções textuais.
    • Caso contrário, se você encontrar um dos tipos primitivos listados em qualquer tabela de tipo primitivo, aplique as regras de mapeamento para tipos primitivos e tipos restritos.
  • Se você encontrar uma das convenções textuais listadas no TEXTUAL_CONVENTION Macro, aplique as regras de mapeamento para convenções textuais.

  • Se você encontrar um dos tipos primitivos listados em qualquer tabela de tipo primitivo, aplique as regras de mapeamento para tipos primitivos.

Observação

As classes que contêm tipos de propriedade que não estão em conformidade com o mapeamento descrito acima não são válidas. Nesse caso, o provedor retornará um erro se e quando o provedor solicitar a recuperação de uma definição de classe durante a execução de uma função de recuperação de instância.

Tipo Restrito

Um tipo restrito é um tipo primitivo, tipo nomeado ou convenção textual que foi restringido por algum mecanismo de subtipagem definido nos documentos SMI RFC 1213 e RFC 1903. Quando ocorre a subtipagem, qualificadores de CIM adicionais são necessários para especificar os valores de subtipo. A definição de tipo nomeado na cláusula SYNTAX é mapeada textualmente para o qualificador de propriedade CIM object_syntax até, mas não incluindo as restrições do subtipo.

Os subtipos podem seguir qualquer um dos seguintes formatos:

  • INTEGER enumerado

    O qualificador de propriedade CIM enumeration especifica os valores enumerados. Esse qualificador é representado como uma cadeia de caracteres que contém uma lista separada por vírgulas de valores inteiros assinados de 32 bits. A tabela a seguir lista os tipos de mapeamento. O valor padrão é sempre NULL.

Tipo de MIB restrito Tipo de variante do CIM Qualificadores do CIM
INTEGER enumerado VT_BSTR textual_convention: enumeratedinteger
encoding: INTEGER
cimtype: string
  • BITS

    O qualificador de propriedade CIM bits especifica os valores enumerados. Esse qualificador é representado como uma cadeia de caracteres que contém uma lista separada por vírgulas de valores inteiros assinados de 32 bits. A tabela a seguir lista os tipos de mapeamento. O valor padrão é sempre NULL.

Tipo de MIB restrito Tipo de variante do CIM Qualificadores do CIM
BITS VT_ARRAY | VT_BSTR textual_convention: bits
encoding: OCTETSTRING
cimtype: string
  • Comprimento variável

    Quando a cláusula SYNTAX se refere a um tipo primitivo, tipo nomeado ou convenção textual que é subtipado como OCTET STRING de comprimento variável ou opaco, o qualificador de propriedade CIM variable_length especifica os valores mínimo, máximo e de comprimento fixo associados à definição de tipo. Esse qualificador é implementado como uma cadeia de caracteres no formato a seguir, em que os valores de comprimento variável são representados como inteiros de 32 bits sem sinal.

    (((0.9) .. (0.9)) | (0.9))(, (((0.9) .. (0.9)) | (0.9)))*
    
  • Comprimento fixo

    Quando a cláusula SYNTAX se refere a um tipo primitivo, tipo nomeado ou convenção textual que é subtipado como OCTET STRING de comprimento fixo ou opaco, o qualificador de propriedade CIM fixed_length especifica o valor de comprimento fixo. Esse qualificador é representado como valor inteiro de 32 bits sem sinal.

  • Intervalo

    Quando a cláusula SYNTAX se refere a um tipo primitivo, tipo nomeado ou convenção textual que é subtipado como INTEGER ou Gauge de valor fixo ou intervalo, o qualificador de propriedade CIM variable_value especifica os valores de intervalo e fixo associados à definição de tipo. Esse qualificador é implementado como uma cadeia de caracteres no formato a seguir, em que os valores de intervalo e comprimento fixo são representados como inteiros de 32 bits sem sinal.

    (((0.9)..(0.9))|(0.9))(,(((0.9)..(0.9))|(0.9)))*
    

Código de exemplo

O exemplo a seguir descreve um subtipo INTEGER enumerado.

Status := INTEGER {
up(1),
down(2),
testing(3)
}

Este exemplo é mapeado para:

enumeration("up(1),down(2),testing(3)")

O exemplo de código a seguir descreve um subtipo BITS.

Status := BITS {
up(1),
down(2), 
testing(3)
}

O exemplo de código a seguir é mapeado para:

bits("up(1),down(2),testing(3)")

O exemplo de código a seguir descreve um subtipo de comprimento variável.

MySnmpOSIAddress ::=  TEXTUAL-CONVENTION

    DISPLAY-HINT    "*1x:/1x:"
    STATUS        current
    DESCRIPTION
            "Represents an OSI transport-address:

            octets    contents         encoding
              1        length of NSAP   'n' as an unsigned-integer
                                        (either 0 or from 3 to 20)
              2..(n+1)  NSAP          concrete binary representation
              (n+2)..m  TSEL             string of (up to 64) octets
            "
    SYNTAX         OCTET STRING (SIZE (1|4..85))

Este exemplo é mapeado para:

display_hint("*1x:/1x:"),
encoding("OCTETSTRING"),
textual_convention("OCTETSTRING"),
variable_length ("1,4..85")

O exemplo a seguir descreve um subtipo de comprimento fixo.

IPXADDRESS := OCTET STRING (SIZE (6))

Este exemplo é mapeado para:

fixed_length(6)

O exemplo a seguir descreve um subtipo de intervalo.

Status := INTEGER (10..20|8)

Este exemplo é mapeado para:

variable_value("10..20,8")