Usando o “Bluetooth Bonjour” do iOS GameKit com outras plataformas

Estou interessado em conectar dispositivos iOS com Bluetooth. Percebo que o serviço "Rede local" está exposto, mas não consigo encontrar nenhuma informação extra sobre ele. A propriedade armazenada na chave 0x0204 se parece com uma chave Bonjour.

Qual protocolo é usado? Como alguém pode conversar com o dispositivo iOS usando Linux, Mac ou o próprio dispositivo incorporado equipado com um chip Bluetooth?

Aqui estão os dados SDP extraídos usando o Bluetooth Explorer no OS X enquanto o dispositivo iOS executa o Star Battalion da Gamelof

    {
        0x0000 = uint32(1330188565),
        0x0200 = uint32(2),
        0x0202 = string(004wD7l1A..0|0|0|ivucic-À'),
        0x030a = uint32(0),
        0x0009 = { { uuid16(11 15), uint16(256) } },
        0x0201 = string(_657o30a6rmst07À),
        0x0005 = { uuid16(10 02) },
        0x0100 = string(Local Network),
        0x0001 = { uuid16(11 15) },
        0x0203 = string(004wd7l1a..0|0|0|ivucic-_657o30a6rmst07À
        0xf000 = uint8(2),
        0x0204 = string(    txtvers=1state=A),
        0x0008 = uint8(255),
        0x0006 = { uint16(25966), uint16(106), uint16(256), uint16(26226), uint16(106), uint16(272), uint16(25701), uint16(106), uint16(288), uint16(27233), uint16(106), uint16(304) },
        0x0004 = { { uuid16(01 00), uint16(15) }, { uuid16(00 0f), uint16(256), { uint16(2048), uint16(2054) } } },
        0x0002 = uint32(0)
    },

Outras perguntas parcialmente relevantes:

PAN com Linux, iOS, Bluetooth, Bonjour, GameKit - Possível? - A pessoa pode resolver o problema usando o Wi-Fi. Não há solução aqui, porque o dispositivo incorporado não terá o chip Wi-Fi mais caro.Bonjour por bluetooth SEM Gamekit? - A melhor resposta não acaba fornecendo detalhes técnicosiOS bluetooth sem GameKit - Fornece uma solução para um dispositivo jailbroken, que não é aplicável aqu

Pesquisando mais com o Bluetooth Explorer da Apple no OS X esdptool no GNU / Linux, eu descobri essa chave0x0001 (sigla para "classe de protocolo"), contendo o valor de0x1115, representa a variante "PANU" de "PAN" - uma variante peer2peer. É notável que o OS X não forneça suporte do lado do serviço ('hospedagem') para esse protocolo, apesar de oferecer suporte à criação de um0x1116 network, que é a variante "NAP" de "PAN" - uma variante cliente / servido

Isso pode ser uma boa notícia, mas apenas se o protocolo de sessão do GameKit não precisar ser usado. Seria ideal seqüestrar a conexão da camada de mídia estabelecida pelo GameKit para enviar outro tráfego UD

Ainda terei que pesquisar se essa conexão GameKit é ou não0x1115; isto é, se é realmente "PANU". Alguém tem mais alguma informação?

Observe que, enquanto o Bonjour anunciava automaticamente esse serviço Bluetooth após o iOS 3, isso foi alterado no iOS 5. Veja a resposta que eu publiquei nocomo estabelecer conexão Bluetooth sem GameKit, onde documentei com facilidade as informações da Apple Perguntas e Respostas Técnicas QA1753.

Uma pequena quantidade de pesquisa com o GNU / Linux não resultou em uma conexão bem-sucedida. Pode ser devido à falta de conhecimento sobre como usar corretamentepand. Também pode ser devido ao bloqueio por Bluetooth MAC. Eu adoraria informações que qualquer pessoa possa oferecer. Se eu pesquisar mais isso e deparar com algo interessante, atualizarei esta resposta.

Resultados no Ubuntu. O serviço aparece apenas quando o Bluetooth Bonjour está ativ

ivucica@ivucica-MacBook:~$ sdptool browse $ADDR #relevant data only
Browsing ADDRESS_HERE ...
Service Name: Local Network
Service RecHandle: 0x4f491115
Service Class ID List:
  "PAN User" (0x1115)
Protocol Descriptor List:
  "L2CAP" (0x0100)
    PSM: 15
  "BNEP" (0x000f)
    Version: 0x0100
    SEQ8: 0 6
Language Base Attr List:
  code_ISO639: 0x656e
  encoding:    0x6a
  base_offset: 0x100
  code_ISO639: 0x6672
  encoding:    0x6a
  base_offset: 0x110
  code_ISO639: 0x6465
  encoding:    0x6a
  base_offset: 0x120
  code_ISO639: 0x6a61
  encoding:    0x6a
  base_offset: 0x130
Profile Descriptor List:
  "PAN User" (0x1115)
    Version: 0x0100

... and so on ...

Aqui está a tentativa de conectar:

ivucica@ivucica-MacBook:~$ pand --connect $ADDR -n
pand[3237]: Bluetooth PAN daemon version 4.98
pand[3237]: Connecting to ADDRESS_HERE
pand[3237]: Connect to ADDRESS_HERE failed. Connection refused(111)

É necessário algum tipo de autorização? Ativar criptografia, autenticação, conexão segura e forçar a criação de um mestre não parece fazer nenhuma diferença -AESM opções em várias combinações

lguém tem alguma idéi

ivucica@ivucica-MacBook:~$ sudo hcidump
HCI sniffer - Bluetooth packet analyzer ver 2.2
device: hci0 snap_len: 1028 filter: 0xffffffff
 HCI Event: Command Status (0x0f) plen 4
    Create Connection (0x01|0x0005) status 0x00 ncmd 1
> HCI Event: Role Change (0x12) plen 8
    status 0x00 bdaddr ADDRESS_HERE role 0x01
    Role: Slave
> HCI Event: Connect Complete (0x03) plen 11
    status 0x00 handle 12 bdaddr ADDRESS_HERE type ACL encrypt 0x00
 HCI Event: Command Status (0x0f) plen 4
    Read Remote Supported Features (0x01|0x001b) status 0x00 ncmd 1
> HCI Event: Read Remote Supported Features (0x0b) plen 11
    status 0x00 handle 12
    Features: 0xbf 0xfe 0x8f 0xfe 0x9b 0xff 0x79 0x83
 HCI Event: Command Status (0x0f) plen 4
    Read Remote Extended Features (0x01|0x001c) status 0x00 ncmd 1
> HCI Event: Max Slots Change (0x1b) plen 3
    handle 12 slots 5
> HCI Event: Read Remote Extended Features (0x23) plen 13
    status 0x00 handle 12 page 1 max 1
    Features: 0x01 0x00 0x00 0x00 0x00 0x00 0x00 0x00
 HCI Event: Command Status (0x0f) plen 4
    Remote Name Request (0x01|0x0019) status 0x00 ncmd 1
> HCI Event: Remote Name Req Complete (0x07) plen 255
    status 0x00 bdaddr ADDRESS_HERE name 'Evil iPad'
 HCI Event: Command Status (0x0f) plen 4
    Authentication Requested (0x01|0x0011) status 0x00 ncmd 1
> HCI Event: Link Key Request (0x17) plen 6
    bdaddr ADDRESS_HERE
 HCI Event: Command Complete (0x0e) plen 10
    Link Key Request Reply (0x01|0x000b) ncmd 1
    status 0x00 bdaddr ADDRESS_HERE
> HCI Event: Auth Complete (0x06) plen 3
    status 0x00 handle 12
 HCI Event: Command Status (0x0f) plen 4
    Set Connection Encryption (0x01|0x0013) status 0x00 ncmd 1
> HCI Event: Encrypt Change (0x08) plen 4
    status 0x00 handle 12 encrypt 0x01
 HCI Event: Number of Completed Packets (0x13) plen 5
    handle 12 packets 1
> ACL data: handle 12 flags 0x02 dlen 16
    L2CAP(s): Info rsp: type 2 result 0
      Extended feature mask 0x02a8
        Enhanced Retransmission mode
        FCS Option
        Fixed Channels
        Unicast Connectless Data Reception
 HCI Event: Number of Completed Packets (0x13) plen 5
    handle 12 packets 1
> ACL data: handle 12 flags 0x02 dlen 20
    L2CAP(s): Info rsp: type 3 result 0
      Fixed channel list 0x00000006
        L2CAP Signalling Channel
        L2CAP Connless
 HCI Event: Number of Completed Packets (0x13) plen 5
    handle 12 packets 1
> ACL data: handle 12 flags 0x02 dlen 16
    L2CAP(s): Connect rsp: dcid 0x0000 scid 0x0040 result 2 status 0
      Connection refused - PSM not supported
> HCI Event: Disconn Complete (0x05) plen 4
    status 0x00 handle 12 reason 0x13
    Reason: Remote User Terminated Connection

Este

> ACL data: handle 12 flags 0x02 dlen 16
    L2CAP(s): Connect rsp: dcid 0x0000 scid 0x0040 result 2 status 0
      Connection refused - PSM not supported

questionAnswers(2)

yourAnswerToTheQuestion