blob: 4c0e19649d81a5d1a07a4c19f83afa1c0b712fad [file] [log] [blame]
/*
*
* Copyright (c) 2020 Project CHIP Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file
* This file describes a QRCode Setup Payload class to hold
* data enumerated from a byte stream
*/
#ifndef _SETUP_PAYLOAD_H_
#define _SETUP_PAYLOAD_H_
#include <map>
#include <stdint.h>
#include <string>
#include <vector>
#include <core/CHIPError.h>
using namespace std;
namespace chip {
// TODO this should point to the spec
const int kVersionFieldLengthInBits = 3;
const int kVendorIDFieldLengthInBits = 16;
const int kProductIDFieldLengthInBits = 16;
const int kCustomFlowRequiredFieldLengthInBits = 1;
const int kRendezvousInfoFieldLengthInBits = 8;
const int kPayloadDiscriminatorFieldLengthInBits = 8;
const int kManualSetupDiscriminatorFieldLengthInBits = 4;
const int kSetupPINCodeFieldLengthInBits = 27;
const int kReservedFieldLengthInBits = 1;
const int kRawVendorTagLengthInBits = 7;
const uint16_t kSerialNumberTag = 128;
const int kManualSetupShortCodeCharLength = 10;
const int kManualSetupLongCodeCharLength = 20;
const int kManualSetupVendorIdCharLength = 5;
const int kManualSetupProductIdCharLength = 5;
const int kTotalPayloadDataSizeInBits =
(kVersionFieldLengthInBits + kVendorIDFieldLengthInBits + kProductIDFieldLengthInBits + kCustomFlowRequiredFieldLengthInBits +
kRendezvousInfoFieldLengthInBits + kPayloadDiscriminatorFieldLengthInBits + kSetupPINCodeFieldLengthInBits +
kReservedFieldLengthInBits);
const int kTotalPayloadDataSizeInBytes = (kTotalPayloadDataSizeInBits + 7) / 8;
const char * const kQRCodePrefix = "CH:";
enum optionalQRCodeInfoType
{
optionalQRCodeInfoTypeString,
optionalQRCodeInfoTypeInt
};
/**
* @brief A struct to hold optional QR Code Info
* @param tag The tag number of the optional info
* @param type The type (String or Int) of the optional info
* @param data If type is optionalQRCodeInfoTypeString,
* the string value of the optional info,
* otherwise should not be set.
* @param integer If type is optionalQRCodeInfoTypeInt,
* the integer value of the optional info,
* otherwise should not be set.
**/
struct OptionalQRCodeInfo
{
uint64_t tag;
enum optionalQRCodeInfoType type;
int integer;
string data;
};
/**
* @brief A function to retrieve a vendor tag
* @param tagNumber Tag number is 7 bits long
* @param outVendorTag A 64-bit integer representing the tag
* to use in OptionalQRCodeInfo
* @return Returns a CHIP_ERROR on error, CHIP_NO_ERROR otherwise
**/
CHIP_ERROR VendorTag(uint16_t tagNumber, uint64_t & outVendorTag);
class SetupPayload
{
public:
uint8_t version;
uint16_t vendorID;
uint16_t productID;
uint8_t requiresCustomFlow;
uint16_t rendezvousInformation;
uint16_t discriminator;
uint32_t setUpPINCode;
string serialNumber;
/**
* @brief A function to retrieve the vector of OptionalQRCodeInfo infos
* @return Returns a vector of optionalQRCodeInfos
**/
vector<OptionalQRCodeInfo> getAllOptionalData();
/** @brief A function to add an optional QR Code info object
* @param info Optional QR code info object to add
* @return Returns a CHIP_ERROR on error, CHIP_NO_ERROR otherwise
**/
CHIP_ERROR addOptionalData(OptionalQRCodeInfo info);
/** @brief A function to remove an optional QR Code info object
* @param tag Optional QR code info tag number to remove
* @return Returns CHIP_ERROR_KEY_NOT_FOUND if info could not be found in existing optional data structs,
* CHIP_NO_ERROR otherwise
**/
CHIP_ERROR removeOptionalData(uint64_t tag);
// Test that the Setup Payload is within expected value ranges
SetupPayload() :
version(0), vendorID(0), productID(0), requiresCustomFlow(0), rendezvousInformation(0), discriminator(0), setUpPINCode(0){};
bool isValidQRCodePayload();
bool isValidManualCode();
bool operator==(const SetupPayload & input);
private:
map<uint64_t, OptionalQRCodeInfo> optionalData;
};
}; // namespace chip
#endif /* _SETUP_PAYLOAD_H_ */