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