114cf0368Sopenharmony_ci/* 214cf0368Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 314cf0368Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 414cf0368Sopenharmony_ci * you may not use this file except in compliance with the License. 514cf0368Sopenharmony_ci * You may obtain a copy of the License at 614cf0368Sopenharmony_ci * 714cf0368Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 814cf0368Sopenharmony_ci * 914cf0368Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 1014cf0368Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 1114cf0368Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1214cf0368Sopenharmony_ci * See the License for the specific language governing permissions and 1314cf0368Sopenharmony_ci * limitations under the License. 1414cf0368Sopenharmony_ci */ 1514cf0368Sopenharmony_ci 1614cf0368Sopenharmony_ci#include "base32_utils.h" 1714cf0368Sopenharmony_ci 1814cf0368Sopenharmony_cinamespace OHOS { 1914cf0368Sopenharmony_cinamespace UDMF { 2014cf0368Sopenharmony_cistatic char BASE32_CHARS[33] = "abcdefghijklmnopqrstuvwxyz234567"; 2114cf0368Sopenharmony_ci 2214cf0368Sopenharmony_cistatic constexpr const uint32_t CHAR_ARRAY_LENGTH = 5; 2314cf0368Sopenharmony_cistatic constexpr const uint32_t ASCII_CHAR_LENGTH = 8; 2414cf0368Sopenharmony_ci 2514cf0368Sopenharmony_cistd::string Base32::Encode(const std::string &input) 2614cf0368Sopenharmony_ci{ 2714cf0368Sopenharmony_ci std::string result; 2814cf0368Sopenharmony_ci uint32_t val = 0; 2914cf0368Sopenharmony_ci uint32_t valbits = 0; 3014cf0368Sopenharmony_ci for (char c : input) { 3114cf0368Sopenharmony_ci val = (val << ASCII_CHAR_LENGTH) + c; 3214cf0368Sopenharmony_ci valbits += ASCII_CHAR_LENGTH; 3314cf0368Sopenharmony_ci while (valbits >= CHAR_ARRAY_LENGTH) { 3414cf0368Sopenharmony_ci valbits -= CHAR_ARRAY_LENGTH; 3514cf0368Sopenharmony_ci uint32_t index = (val >> valbits) & 0x1f; // the 31st place. 3614cf0368Sopenharmony_ci result += BASE32_CHARS[index]; 3714cf0368Sopenharmony_ci } 3814cf0368Sopenharmony_ci } 3914cf0368Sopenharmony_ci if (valbits > 0) { 4014cf0368Sopenharmony_ci val <<= (CHAR_ARRAY_LENGTH - valbits); 4114cf0368Sopenharmony_ci uint32_t index = val & 0x1f; // the 31st place. 4214cf0368Sopenharmony_ci result += BASE32_CHARS[index]; 4314cf0368Sopenharmony_ci } 4414cf0368Sopenharmony_ci return result; 4514cf0368Sopenharmony_ci} 4614cf0368Sopenharmony_ci 4714cf0368Sopenharmony_cistd::string Base32::Decode(const std::string &input) 4814cf0368Sopenharmony_ci{ 4914cf0368Sopenharmony_ci std::string result; 5014cf0368Sopenharmony_ci uint32_t val = 0; 5114cf0368Sopenharmony_ci uint32_t valbits = 0; 5214cf0368Sopenharmony_ci for (char c : input) { 5314cf0368Sopenharmony_ci if (c >= 'a' && c <= 'z') { 5414cf0368Sopenharmony_ci val = (val << CHAR_ARRAY_LENGTH) + (c - 'a'); 5514cf0368Sopenharmony_ci valbits += CHAR_ARRAY_LENGTH; 5614cf0368Sopenharmony_ci } else if (c >= '2' && c <= '7') { 5714cf0368Sopenharmony_ci val = (val << CHAR_ARRAY_LENGTH) + (c - '2' + 26); // 26 : a-z 5814cf0368Sopenharmony_ci valbits += CHAR_ARRAY_LENGTH; 5914cf0368Sopenharmony_ci } 6014cf0368Sopenharmony_ci if (valbits >= ASCII_CHAR_LENGTH) { 6114cf0368Sopenharmony_ci valbits -= ASCII_CHAR_LENGTH; 6214cf0368Sopenharmony_ci result += static_cast<char>(val >> valbits); 6314cf0368Sopenharmony_ci val &= (1 << valbits) - 1; 6414cf0368Sopenharmony_ci } 6514cf0368Sopenharmony_ci } 6614cf0368Sopenharmony_ci return result; 6714cf0368Sopenharmony_ci} 6814cf0368Sopenharmony_ci 6914cf0368Sopenharmony_ci} // namespace UDMF 7014cf0368Sopenharmony_ci} // namespace OHOS 7114cf0368Sopenharmony_ci 72