| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- /* network_management.proto/Open GoPro, Version 2.0 (C) Copyright 2021 GoPro, Inc. (http://gopro.com/OpenGoPro). */
- /* This copyright was auto-generated on Mon Nov 4 18:00:55 UTC 2024 */
- /***********************************************************************************************************************
- *
- * This file is automatically generated!!! Do not modify manually.
- *
- **********************************************************************************************************************/
- /**
- * Defines the structure of protobuf messages for network management
- */
- syntax = "proto2";
- package open_gopro;
- import "response_generic.proto";
- enum EnumProvisioning {
- PROVISIONING_UNKNOWN = 0;
- PROVISIONING_NEVER_STARTED = 1;
- PROVISIONING_STARTED = 2;
- PROVISIONING_ABORTED_BY_SYSTEM = 3;
- PROVISIONING_CANCELLED_BY_USER = 4;
- PROVISIONING_SUCCESS_NEW_AP = 5;
- PROVISIONING_SUCCESS_OLD_AP = 6;
- PROVISIONING_ERROR_FAILED_TO_ASSOCIATE = 7;
- PROVISIONING_ERROR_PASSWORD_AUTH = 8;
- PROVISIONING_ERROR_EULA_BLOCKING = 9;
- PROVISIONING_ERROR_NO_INTERNET = 10;
- PROVISIONING_ERROR_UNSUPPORTED_TYPE = 11;
- }
- enum EnumScanning {
- SCANNING_UNKNOWN = 0;
- SCANNING_NEVER_STARTED = 1;
- SCANNING_STARTED = 2;
- SCANNING_ABORTED_BY_SYSTEM = 3;
- SCANNING_CANCELLED_BY_USER = 4;
- SCANNING_SUCCESS = 5;
- }
- /*
- * Provision state notification
- *
- * Sent during provisioning triggered via @ref RequestConnect or @ref RequestConnectNew
- */
- message NotifProvisioningState {
- required EnumProvisioning provisioning_state = 1; // Provisioning / connection state
- }
- /*
- * Scanning state notification
- *
- * Triggered via @ref RequestStartScan
- */
- message NotifStartScanning {
- required EnumScanning scanning_state = 1; // Scanning state
- optional int32 scan_id = 2; // ID associated with scan results (included if scan was successful)
- optional int32 total_entries = 3; // Number of APs found during scan (included if scan was successful)
- required int32 total_configured_ssid = 4; // Total count of camera's provisioned SSIDs
- }
- /**
- * Connect to (but do not authenticate with) an Access Point
- *
- * This is intended to be used to connect to a previously-connected Access Point
- *
- * Response: @ref ResponseConnect
- *
- * Notification: @ref NotifProvisioningState sent periodically as provisioning state changes
- */
- message RequestConnect {
- required string ssid = 1; // AP SSID
- }
- /**
- * Connect to and authenticate with an Access Point
- *
- * This is only intended to be used if the AP is not previously provisioned.
- *
- * Response: @ref ResponseConnectNew sent immediately
- *
- * Notification: @ref NotifProvisioningState sent periodically as provisioning state changes
- */
- message RequestConnectNew {
- required string ssid = 1; // AP SSID
- required string password = 2; // AP password
- optional bytes static_ip = 3; // Static IP address
- optional bytes gateway = 4; // Gateway IP address
- optional bytes subnet = 5; // Subnet mask
- optional bytes dns_primary = 6; // Primary DNS
- optional bytes dns_secondary = 7; // Secondary DNS
- optional bool bypass_eula_check = 10; // Allow network configuration without internet connectivity
- }
- /**
- * Get a list of Access Points found during a @ref RequestStartScan
- *
- * Response: @ref ResponseGetApEntries
- */
- message RequestGetApEntries {
- required int32 start_index = 1; // Used for paging. 0 <= start_index < @ref ResponseGetApEntries .total_entries
- required int32 max_entries = 2; // Used for paging. Value must be < @ref ResponseGetApEntries .total_entries
- required int32 scan_id = 3; // ID corresponding to a set of scan results (i.e. @ref ResponseGetApEntries .scan_id)
- }
- /**
- * Request to disconnect from currently-connected AP
- *
- * This drops the camera out of Station (STA) Mode and returns it to Access Point (AP) mode.
- *
- * Response: @ref ResponseGeneric
- */
- message RequestReleaseNetwork {}
- /**
- * Start scanning for Access Points
- *
- * @note Serialization of this object is zero bytes.
- *
- * Response: @ref ResponseStartScanning are sent immediately after the camera receives this command
- *
- * Notifications: @ref NotifStartScanning are sent periodically as scanning state changes. Use to detect scan complete.
- */
- message RequestStartScan {}
- /**
- * The status of an attempt to connect to an Access Point
- *
- * Sent as the initial response to @ref RequestConnect
- */
- message ResponseConnect {
- required EnumResultGeneric result = 1; // Generic pass/fail/error info
- required EnumProvisioning provisioning_state = 2; // Provisioning/connection state
- required int32 timeout_seconds = 3; // Network connection timeout (seconds)
- }
- /**
- * The status of an attempt to connect to an Access Point
- *
- * Sent as the initial response to @ref RequestConnectNew
- */
- message ResponseConnectNew {
- required EnumResultGeneric result = 1; // Status of Connect New request
- required EnumProvisioning provisioning_state = 2; // Current provisioning state of the network
- /**
- * Number of seconds camera will wait before declaring a network connection attempt failed
- */
- required int32 timeout_seconds = 3;
- }
- enum EnumScanEntryFlags {
- SCAN_FLAG_OPEN = 0x00; // This network does not require authentication
- SCAN_FLAG_AUTHENTICATED = 0x01; // This network requires authentication
- SCAN_FLAG_CONFIGURED = 0x02; // This network has been previously provisioned
- SCAN_FLAG_BEST_SSID = 0x04;
- SCAN_FLAG_ASSOCIATED = 0x08; // Camera is connected to this AP
- SCAN_FLAG_UNSUPPORTED_TYPE = 0x10;
- }
- /**
- * A list of scan entries describing a scanned Access Point
- *
- * This is sent in response to a @ref RequestGetApEntries
- */
- message ResponseGetApEntries {
- required EnumResultGeneric result = 1; // Generic pass/fail/error info
- required int32 scan_id = 2; // ID associated with this batch of results
- /**
- * An individual Scan Entry in a @ref ResponseGetApEntries response
- *
- * @note When `scan_entry_flags` contains `SCAN_FLAG_CONFIGURED`, it is an indication that this network has already been provisioned.
- */
- message ScanEntry {
- required string ssid = 1; // AP SSID
- required int32 signal_strength_bars = 2; // Signal strength (3 bars: >-70 dBm; 2 bars: >-85 dBm; 1 bar: <=-85 dBm)
- required int32 signal_frequency_mhz = 4; // Signal frequency (MHz)
- required int32 scan_entry_flags = 5; // Bitmasked value from @ref EnumScanEntryFlags
- }
- repeated ScanEntry entries = 3; // Array containing details about discovered APs
- }
- /**
- * The current scanning state.
- *
- * This is the initial response to a @ref RequestStartScan
- */
- message ResponseStartScanning {
- required EnumResultGeneric result = 1; // Generic pass/fail/error info
- required EnumScanning scanning_state = 2; // Scanning state
- }
- /**
- * Set Wireless 2.0 Pairing State
- *
- * This is often colloquially referred to as "sending pairing complete"
- *
- * Response: @ref ResponseGeneric
- */
- message RequestPairingFinish {
- required EnumPairingFinishState result = 1; // Pairing state to set
- /**
- * This must be a non empty string but it does not actually affect anything.
- */
- required string phoneName = 2;
- }
- enum EnumPairingFinishState {
- SUCCESS = 0;
- FAILED = 1;
- }
|