编译问题
@ -15,7 +15,7 @@
|
||||
{
|
||||
"module": {
|
||||
"name": "phone",
|
||||
"type": "feature",
|
||||
"type": "entry",
|
||||
"srcEntry": "./ets/Application/AbilityStage.ts",
|
||||
"description": "$string:mainability_description",
|
||||
"mainElement": "MainAbility",
|
||||
@ -38,7 +38,7 @@
|
||||
"abilities": [
|
||||
{
|
||||
"name": "MainAbility",
|
||||
"srcEntry": "./ets/Application/AbilityStage.ts",
|
||||
"srcEntrance": "./ets/Application/AbilityStage.ts",
|
||||
"description": "$string:mainability_description",
|
||||
"icon": "$media:icon",
|
||||
"label": "$string:entry_MainAbility",
|
||||
|
@ -267,10 +267,6 @@
|
||||
{
|
||||
"name": "TrustedEvidence_tabs_backgroundColor_F1F3F5",
|
||||
"value": "#F1F3F5"
|
||||
},
|
||||
{
|
||||
"name": "color_1",
|
||||
"value": "#FFFFFF"
|
||||
}
|
||||
]
|
||||
}
|
6
application/.gitignore
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
/node_modules
|
||||
/oh_modules
|
||||
/.preview
|
||||
/build
|
||||
/.cxx
|
||||
/.test
|
34
application/build-profile.json5
Normal file
@ -0,0 +1,34 @@
|
||||
{
|
||||
"apiType": "stageMode",
|
||||
"buildOption": {
|
||||
"arkOptions": {
|
||||
// "apPath": "./modules.ap" /* Profile used for profile-guided optimization (PGO), a compiler optimization technique to improve app runtime performance. */
|
||||
}
|
||||
},
|
||||
"buildOptionSet": [
|
||||
{
|
||||
"name": "release",
|
||||
"arkOptions": {
|
||||
"obfuscation": {
|
||||
"ruleOptions": {
|
||||
"enable": true,
|
||||
"files": [
|
||||
"./obfuscation-rules.txt"
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
],
|
||||
"entryModules": [
|
||||
"entry"
|
||||
],
|
||||
"targets": [
|
||||
{
|
||||
"name": "default"
|
||||
},
|
||||
{
|
||||
"name": "ohosTest",
|
||||
}
|
||||
]
|
||||
}
|
6
application/hvigorfile.ts
Normal file
@ -0,0 +1,6 @@
|
||||
import { hapTasks } from '@ohos/hvigor-ohos-plugin';
|
||||
|
||||
export default {
|
||||
system: hapTasks, /* Built-in plugin of Hvigor. It cannot be modified. */
|
||||
plugins:[] /* Custom plugin to extend the functionality of Hvigor. */
|
||||
}
|
18
application/obfuscation-rules.txt
Normal file
@ -0,0 +1,18 @@
|
||||
# Define project specific obfuscation rules here.
|
||||
# You can include the obfuscation configuration files in the current module's build-profile.json5.
|
||||
#
|
||||
# For more details, see
|
||||
# https://gitee.com/openharmony/arkcompiler_ets_frontend/blob/master/arkguard/README.md
|
||||
|
||||
# Obfuscation options:
|
||||
# -disable-obfuscation: disable all obfuscations
|
||||
# -enable-property-obfuscation: obfuscate the property names
|
||||
# -enable-toplevel-obfuscation: obfuscate the names in the global scope
|
||||
# -compact: remove unnecessary blank spaces and all line feeds
|
||||
# -remove-log: remove all console.* statements
|
||||
# -print-namecache: print the name cache that contains the mapping from the old names to new names
|
||||
# -apply-namecache: reuse the given cache file
|
||||
|
||||
# Keep options:
|
||||
# -keep-property-name: specifies property names that you want to keep
|
||||
# -keep-global-name: specifies names that you want to keep in the global scope
|
10
application/oh-package.json5
Normal file
@ -0,0 +1,10 @@
|
||||
{
|
||||
"license": "",
|
||||
"devDependencies": {},
|
||||
"author": "",
|
||||
"name": "application",
|
||||
"description": "Please describe the basic information.",
|
||||
"main": "",
|
||||
"version": "1.0.0",
|
||||
"dependencies": {}
|
||||
}
|
192
application/src/main/ets/@ohos.security.certManager.d.ts
vendored
Normal file
@ -0,0 +1,192 @@
|
||||
/*
|
||||
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export interface AsyncCallback<T, E = void> {
|
||||
(err: BusinessError<E>, data: T): void;
|
||||
}
|
||||
|
||||
export interface BusinessError<T = void> extends Error {
|
||||
code: number;
|
||||
data?: T;
|
||||
}
|
||||
|
||||
declare namespace CertManagerFunc {
|
||||
function getSystemTrustedCertificateList(callback: AsyncCallback<CMResult>) : void;
|
||||
function getSystemTrustedCertificateList() : Promise<CMResult>;
|
||||
|
||||
function getSystemTrustedCertificate(certUri: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function getSystemTrustedCertificate(certUri: string) : Promise<CMResult>;
|
||||
|
||||
function setCertificateStatus(certUri: string, store: number, status: boolean, callback: AsyncCallback<boolean>) : void;
|
||||
function setCertificateStatus(certUri: string, store: number, status: boolean) : Promise<boolean>;
|
||||
|
||||
function installUserTrustedCertificate(certificate: CertBlob, callback: AsyncCallback<CMResult>) : void;
|
||||
function installUserTrustedCertificate(certificate: CertBlob,) : Promise<CMResult>;
|
||||
|
||||
function uninstallAllUserTrustedCertificate(callback: AsyncCallback<boolean>) : void;
|
||||
function uninstallAllUserTrustedCertificate() : Promise<boolean>;
|
||||
|
||||
function uninstallUserTrustedCertificate(certUri: string, callback: AsyncCallback<boolean>) : void;
|
||||
function uninstallUserTrustedCertificate(certUri: string) : Promise<boolean>;
|
||||
|
||||
function getUserTrustedCertificateList(callback: AsyncCallback<CMResult>) : void;
|
||||
function getUserTrustedCertificateList() : Promise<CMResult>;
|
||||
|
||||
function getUserTrustedCertificate(certUri: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function getUserTrustedCertificate(certUri: string) : Promise<CMResult>;
|
||||
|
||||
function installAppCertificate(keystore: Uint8Array, keystorePwd: string, certAlias: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function installAppCertificate(keystore: Uint8Array, keystorePwd: string, certAlias: string) : Promise<CMResult>;
|
||||
|
||||
function installPrivateCertificate(keystore: Uint8Array, keystorePwd: string, certAlias: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function installPrivateCertificate(keystore: Uint8Array, keystorePwd: string, certAlias: string) : Promise<CMResult>;
|
||||
|
||||
function generatePrivateCertificate(keyAlias: string, keyProperties: CMKeyProperties, callback: AsyncCallback<CMResult>) : void;
|
||||
function generatePrivateCertificate(keyAlias: string, keyProperties: CMKeyProperties) : Promise<CMResult>;
|
||||
|
||||
function updatePrivateCertificate(type: string, keyUri: string, certificate: CertBlob, callback: AsyncCallback<boolean>) : void;
|
||||
function updatePrivateCertificate(type: string, keyUri: string, certificate: CertBlob) : Promise<boolean>;
|
||||
|
||||
function uninstallAllAppCertificate(callback: AsyncCallback<boolean>) : void;
|
||||
function uninstallAllAppCertificate() : Promise<boolean>;
|
||||
|
||||
function uninstallAppCertificate(keyUri: string, callback: AsyncCallback<boolean>) : void;
|
||||
function uninstallAppCertificate(keyUri: string) : Promise<boolean>;
|
||||
|
||||
function uninstallPrivateCertificate(keyUri: string, callback: AsyncCallback<boolean>) : void;
|
||||
function uninstallPrivateCertificate(keyUri: string) : Promise<boolean>;
|
||||
|
||||
function getAppCertificateList(callback: AsyncCallback<CMResult>) : void;
|
||||
function getAppCertificateList() : Promise<CMResult>;
|
||||
|
||||
function getPrivateCertificateList(callback: AsyncCallback<CMResult>) : void;
|
||||
function getPrivateCertificateList() : Promise<CMResult>;
|
||||
|
||||
function getAppCertificate(keyUri: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function getAppCertificate(keyUri: string, ) : Promise<CMResult>;
|
||||
|
||||
function getPrivateCertificate(keyUri: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function getPrivateCertificate(keyUri: string) : Promise<CMResult>;
|
||||
|
||||
function grantAppCertificate(keyUri: string, clientAppUid: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function grantAppCertificate(keyUri: string, clientAppUid: string) : Promise<CMResult>;
|
||||
|
||||
function isAuthorizedApp(keyUri: string, callback: AsyncCallback<boolean>) : void;
|
||||
function isAuthorizedApp(keyUri: string) : Promise<boolean>;
|
||||
|
||||
function getAuthorizedAppList(keyUri: string, callback: AsyncCallback<CMResult>) : void;
|
||||
function getAuthorizedAppList(keyUri: string) : Promise<CMResult>;
|
||||
|
||||
function removeGrantedAppCertificate(keyUri: string, clientAppUid: string, callback: AsyncCallback<boolean>) : void;
|
||||
function removeGrantedAppCertificate(keyUri: string, clientAppUid: string) : Promise<boolean>;
|
||||
|
||||
function init(authUri: string, spec: CMSignatureSpec, callback: AsyncCallback<CMHandle>) : void;
|
||||
function init(authUri: string, spec: CMSignatureSpec) : Promise<CMHandle>;
|
||||
|
||||
function update(handle: Uint8Array, data: Uint8Array, callback: AsyncCallback<boolean>) : void;
|
||||
function update(handle: Uint8Array, data: Uint8Array) : Promise<boolean>;
|
||||
|
||||
function finish(handle: Uint8Array, callback: AsyncCallback<CMResult>) : void;
|
||||
function finish(handle: Uint8Array, signature: Uint8Array, callback: AsyncCallback<CMResult>) : void;
|
||||
function finish(handle: Uint8Array, signature?: Uint8Array) : Promise<CMResult>;
|
||||
|
||||
function abort(handle: Uint8Array, callback: AsyncCallback<boolean>) : void;
|
||||
function abort(handle: Uint8Array) : Promise<boolean>;
|
||||
|
||||
export interface CertInfo {
|
||||
uri: string;
|
||||
certAlias: string;
|
||||
status: boolean;
|
||||
issuerName: string;
|
||||
subjectName: string;
|
||||
serial: string;
|
||||
notBefore: string;
|
||||
notAfter: string;
|
||||
fingerprintSha256: string;
|
||||
cert: Uint8Array;
|
||||
}
|
||||
|
||||
export interface CertAbstract {
|
||||
uri: string;
|
||||
certAlias: string;
|
||||
status: boolean;
|
||||
subjectName: string;
|
||||
}
|
||||
|
||||
export interface Credential {
|
||||
type: string;
|
||||
alias: string;
|
||||
keyUri: string;
|
||||
certNum: number;
|
||||
keyNum: number;
|
||||
credData:Uint8Array;
|
||||
}
|
||||
|
||||
export interface CredentialAbstract {
|
||||
type: string;
|
||||
alias: string;
|
||||
keyUri: string;
|
||||
}
|
||||
|
||||
export interface CertBlob {
|
||||
inData: Uint8Array;
|
||||
alias: string;
|
||||
}
|
||||
|
||||
export interface CMResult {
|
||||
certList?: Array<CertAbstract>;
|
||||
certInfo?: CertInfo;
|
||||
credentialList?: Array<CredentialAbstract>;
|
||||
credential?: Credential;
|
||||
appUidList?: Array<string>;
|
||||
uri?: string;
|
||||
outData?: Uint8Array;
|
||||
isAuth?: boolean;
|
||||
}
|
||||
|
||||
export interface CMKeyProperties {
|
||||
type: string;
|
||||
alg: string;
|
||||
size: number;
|
||||
padding: string;
|
||||
purpose: string;
|
||||
digest: string;
|
||||
authType: string;
|
||||
authTimeout: string;
|
||||
}
|
||||
|
||||
export enum CmKeyPurpose {
|
||||
CM_KEY_PURPOSE_SIGN = 4,
|
||||
CM_KEY_PURPOSE_VERIFY = 8,
|
||||
}
|
||||
|
||||
export interface CMSignatureSpec {
|
||||
purpose: CmKeyPurpose;
|
||||
}
|
||||
|
||||
export interface CMHandle {
|
||||
handle: Uint8Array;
|
||||
}
|
||||
|
||||
export enum CMErrorCode {
|
||||
CM_SUCCESS = 0,
|
||||
CM_ERROR_INNER_ERROR = 17500001,
|
||||
CM_ERROR_NO_PERMISSION = 17500002,
|
||||
CM_ERROR_NO_FOUND = 17500003,
|
||||
CM_ERROR_X509_FORMATE = 17500004,
|
||||
}
|
||||
}
|
||||
|
||||
export default CertManagerFunc;
|
22
application/src/main/ets/Application/AbilityStage.ts
Normal file
@ -0,0 +1,22 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import AbilityStage from '@ohos.app.ability.AbilityStage';
|
||||
|
||||
export default class MyAbilityStage extends AbilityStage {
|
||||
onCreate(): void {
|
||||
console.log('[Demo] MyAbilityStage onCreate');
|
||||
}
|
||||
}
|
64
application/src/main/ets/MainAbility/MainAbility.ts
Normal file
@ -0,0 +1,64 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import Ability from '@ohos.app.ability.UIAbility';
|
||||
import type Want from '@ohos.app.ability.Want';
|
||||
import type Window from '@ohos.window';
|
||||
import { GlobalContext, PwdStore } from '../common/GlobalContext';
|
||||
|
||||
export default class MainAbility extends Ability {
|
||||
onCreate(want: Want, launchParam): void {
|
||||
console.log('[Demo] MainAbility onCreate');
|
||||
let pwdStore = new PwdStore();
|
||||
GlobalContext.getContext().setCmContext(this.context);
|
||||
GlobalContext.getContext().setPwdStore(pwdStore);
|
||||
GlobalContext.getContext().setAbilityWant(want);
|
||||
}
|
||||
|
||||
onDestroy(): void {
|
||||
console.log('[Demo] MainAbility onDestroy');
|
||||
}
|
||||
|
||||
onWindowStageCreate(windowStage: Window.WindowStage): void {
|
||||
// Main window is created, set main page for this ability
|
||||
console.log('[Demo] MainAbility onWindowStageCreate');
|
||||
windowStage.loadContent('pages/certManagerFa', (err, data) => {
|
||||
if (err.code) {
|
||||
console.error('onWindowStageCreate failed, cause:' + JSON.stringify(err));
|
||||
return;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
onWindowStageDestroy(): void {
|
||||
// Main window is destroyed, release UI related resources
|
||||
console.log('[Demo] MainAbility onWindowStageDestroy');
|
||||
}
|
||||
|
||||
onForeground(): void {
|
||||
// Ability has brought to foreground
|
||||
console.log('[Demo] MainAbility onForeground');
|
||||
}
|
||||
|
||||
onBackground(): void {
|
||||
// Ability has back to background
|
||||
console.log('[Demo] MainAbility onBackground');
|
||||
}
|
||||
|
||||
onNewWant(want: Want): void {
|
||||
console.log('[Demo] MainAbility onNewWant');
|
||||
GlobalContext.getContext().setAbilityWant(want);
|
||||
}
|
||||
};
|
@ -0,0 +1,43 @@
|
||||
import AbilityConstant from '@ohos.app.ability.AbilityConstant';
|
||||
import hilog from '@ohos.hilog';
|
||||
import UIAbility from '@ohos.app.ability.UIAbility';
|
||||
import Want from '@ohos.app.ability.Want';
|
||||
import window from '@ohos.window';
|
||||
|
||||
export default class ApplicationAbility extends UIAbility {
|
||||
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
|
||||
}
|
||||
|
||||
onDestroy(): void {
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');
|
||||
}
|
||||
|
||||
onWindowStageCreate(windowStage: window.WindowStage): void {
|
||||
// Main window is created, set main page for this ability
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');
|
||||
|
||||
windowStage.loadContent('pages/Index', (err, data) => {
|
||||
if (err.code) {
|
||||
hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');
|
||||
return;
|
||||
}
|
||||
hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', JSON.stringify(data) ?? '');
|
||||
});
|
||||
}
|
||||
|
||||
onWindowStageDestroy(): void {
|
||||
// Main window is destroyed, release UI related resources
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy');
|
||||
}
|
||||
|
||||
onForeground(): void {
|
||||
// Ability has brought to foreground
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
|
||||
}
|
||||
|
||||
onBackground(): void {
|
||||
// Ability has back to background
|
||||
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
|
||||
}
|
||||
}
|
75
application/src/main/ets/common/GlobalContext.ts
Normal file
@ -0,0 +1,75 @@
|
||||
/*
|
||||
* Copyright (c) 2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import type Want from '@ohos.app.ability.Want';
|
||||
import type UIAbilityContext from 'application/UIAbilityContext';
|
||||
|
||||
export class PwdStore {
|
||||
private certPwd: string = '';
|
||||
setCertPwd(pwd: string): void {
|
||||
this.certPwd = pwd;
|
||||
}
|
||||
|
||||
getCertPwd(): string {
|
||||
return this.certPwd;
|
||||
}
|
||||
|
||||
clearCertPwd(): void {
|
||||
this.certPwd = '';
|
||||
}
|
||||
}
|
||||
|
||||
export class GlobalContext {
|
||||
private constructor() {};
|
||||
private static instance: GlobalContext;
|
||||
private context: UIAbilityContext;
|
||||
private want: Want;
|
||||
private pwdStore: PwdStore;
|
||||
|
||||
public static getContext(): GlobalContext {
|
||||
if (!GlobalContext.instance) {
|
||||
GlobalContext.instance = new GlobalContext();
|
||||
}
|
||||
return GlobalContext.instance;
|
||||
}
|
||||
|
||||
getCmContext(): UIAbilityContext {
|
||||
return this.context;
|
||||
}
|
||||
|
||||
getPwdStore(): PwdStore {
|
||||
return this.pwdStore;
|
||||
}
|
||||
|
||||
getAbilityWant(): Want {
|
||||
return this.want;
|
||||
}
|
||||
|
||||
setCmContext(context: UIAbilityContext): void {
|
||||
this.context = context;
|
||||
}
|
||||
|
||||
setPwdStore(pwdStore: PwdStore): void {
|
||||
this.pwdStore = pwdStore;
|
||||
}
|
||||
|
||||
setAbilityWant(want: Want): void {
|
||||
this.want = want;
|
||||
}
|
||||
|
||||
clearAbilityWantUri(): void {
|
||||
this.want.uri = '';
|
||||
}
|
||||
}
|
@ -0,0 +1,37 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class ComponentConfig {
|
||||
public WH_100_100 = '100%';
|
||||
public WH_30_100 = '30%';
|
||||
public WH_33_100 = '33%';
|
||||
public WH_35_100 = '35%';
|
||||
public WH_40_100 = '40%';
|
||||
public WH_45_100 = '45%';
|
||||
public WH_50_100 = '50%';
|
||||
public WH_55_100 = '55%';
|
||||
public WH_83_100 = '83%';
|
||||
public WH_90_100 = '90%';
|
||||
public value_20 = 20;
|
||||
public font_20 = 20;
|
||||
public MAX_LINES_1 = 1;
|
||||
public MAX_LINES_2 = 2;
|
||||
public MAX_LINES_3 = 3;
|
||||
public DURATION_TIME = 200;
|
||||
}
|
||||
|
||||
let componentConfig = new ComponentConfig();
|
||||
|
||||
export default componentConfig as ComponentConfig;
|
74
application/src/main/ets/common/component/headComponent.ets
Normal file
@ -0,0 +1,74 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
import ComponentConfig from './ComponentConfig';
|
||||
import Router from '@ohos.router';
|
||||
import { GlobalContext } from '../GlobalContext';
|
||||
|
||||
const TAG = 'CertManager HeadComponent: ';
|
||||
|
||||
/**
|
||||
* head custom component
|
||||
*/
|
||||
@Component
|
||||
export default struct HeadComponent {
|
||||
private icBackIsVisibility: boolean = true;
|
||||
private headName: string | Resource = '';
|
||||
@State isTouch: boolean = false;
|
||||
|
||||
build() {
|
||||
Row() {
|
||||
Stack({ alignContent: Alignment.Center }) {
|
||||
Image($r('app.media.ic_back'))
|
||||
.width($r('app.float.wh_value_24'))
|
||||
.height($r('app.float.wh_value_24'))
|
||||
.fillColor($r('sys.color.ohos_id_color_primary'))
|
||||
}
|
||||
.margin({ right: $r('app.float.wh_value_16') })
|
||||
.backgroundColor(this.isTouch ? $r('app.color.color_E3E3E3_grey') : $r('app.color.color_00000000_transparent'))
|
||||
.visibility(this.icBackIsVisibility ? Visibility.Visible : Visibility.None)
|
||||
.onClick(() => {
|
||||
let length = Router.getLength();
|
||||
console.log(TAG + 'router length: ' + Number(length));
|
||||
Number(length) == 1 ? GlobalContext.getContext().getCmContext().terminateSelf() : Router.back();
|
||||
})
|
||||
.onTouch((event?: TouchEvent) => {
|
||||
if (event !== undefined) {
|
||||
if (event.type === TouchType.Down) {
|
||||
this.isTouch = true;
|
||||
}
|
||||
if (event.type === TouchType.Up) {
|
||||
this.isTouch = false;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
Text(this.headName)
|
||||
.fontSize($r('app.float.head_font_20'))
|
||||
.lineHeight($r('app.float.wh_value_33'))
|
||||
.fontFamily('HarmonyHeiTi-Bold')
|
||||
.fontWeight(FontWeight.Regular)
|
||||
.fontColor($r('app.color.font_color_182431'))
|
||||
.maxLines(ComponentConfig.MAX_LINES_1)
|
||||
.textOverflow({ overflow: TextOverflow.Ellipsis })
|
||||
.textAlign(TextAlign.Start)
|
||||
.margin({ top: $r('app.float.wh_value_13'), bottom: $r('app.float.wh_value_15') });
|
||||
}
|
||||
.width(ComponentConfig.WH_100_100)
|
||||
.padding({ left: $r('app.float.wh_value_12') })
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.alignItems(VerticalAlign.Center)
|
||||
.align(Alignment.Start)
|
||||
}
|
||||
}
|
144
application/src/main/ets/common/component/subEntryComponent.ets
Normal file
@ -0,0 +1,144 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
import ComponentConfig from './ComponentConfig';
|
||||
|
||||
/**
|
||||
* Sub-Page Entry Component
|
||||
*/
|
||||
@Component
|
||||
export struct SubEntryComponent {
|
||||
private targetPage: string = '';
|
||||
private title: string | Resource = '';
|
||||
@State isTouched: boolean = false;
|
||||
|
||||
build() {
|
||||
Navigator({ target: this.targetPage }) {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
Row() {
|
||||
Text(this.title)
|
||||
.fontSize($r('app.float.font_16'))
|
||||
.lineHeight($r('app.float.wh_value_22'))
|
||||
.fontColor($r('app.color.font_color_182431'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({ left: $r('app.float.wh_value_8') })
|
||||
.textAlign(TextAlign.Start);
|
||||
}
|
||||
|
||||
Image($r('app.media.ic_settings_arrow'))
|
||||
.width($r('app.float.wh_value_12'))
|
||||
.height($r('app.float.wh_value_24'))
|
||||
.fillColor($r('sys.color.ohos_id_color_primary'))
|
||||
.opacity($r('app.float.opacity_0_2'))
|
||||
.margin({ right: $r('app.float.wh_value_8') });
|
||||
}
|
||||
.borderRadius($r('app.float.radius_20'))
|
||||
.height(ComponentConfig.WH_100_100)
|
||||
.width(ComponentConfig.WH_100_100)
|
||||
.linearGradient(this.isTouched ? {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('app.color.DCEAF9'), 0.0], [$r('app.color.FAFAFA'), 1.0]]
|
||||
} : {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('sys.color.ohos_id_color_foreground_contrary'), 1],
|
||||
[$r('sys.color.ohos_id_color_foreground_contrary'), 1]]
|
||||
})
|
||||
.onTouch((event?: TouchEvent) => {
|
||||
if (event !== undefined) {
|
||||
if (event.type === TouchType.Down) {
|
||||
this.isTouched = true;
|
||||
}
|
||||
if (event.type === TouchType.Up) {
|
||||
this.isTouched = false;
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
.height($r('app.float.wh_value_48'))
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Sub-Page Entry Component with EndText
|
||||
*/
|
||||
@Component
|
||||
export struct SubEntryComponentWithEndText {
|
||||
@State isTouched: boolean = false;
|
||||
@Prop endText: string = '';
|
||||
private targetPage: string = '';
|
||||
private title: string | Resource = '';
|
||||
|
||||
build() {
|
||||
Navigator({ target: this.targetPage }) {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
Row() {
|
||||
Text(this.title)
|
||||
.fontSize($r('app.float.font_16'))
|
||||
.lineHeight($r('app.float.wh_value_22'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('app.color.font_color_182431'))
|
||||
.margin({ left: $r('app.float.distance_8') })
|
||||
.textAlign(TextAlign.Start);
|
||||
}
|
||||
|
||||
Row() {
|
||||
Text(this.endText)
|
||||
.fontSize($r('app.float.font_14'))
|
||||
.lineHeight($r('app.float.wh_value_19'))
|
||||
.fontWeight(FontWeight.Regular)
|
||||
.fontColor($r('sys.color.ohos_id_color_text_secondary'))
|
||||
.margin({ right: $r('app.float.distance_4') })
|
||||
.textAlign(TextAlign.End);
|
||||
Image('/res/image/ic_settings_arrow.svg')
|
||||
.width($r('app.float.wh_value_12'))
|
||||
.height($r('app.float.wh_value_24'))
|
||||
.margin({ right: $r('app.float.distance_8') })
|
||||
.fillColor($r('sys.color.ohos_id_color_primary'))
|
||||
.opacity($r('app.float.opacity_0_2'))
|
||||
}
|
||||
}
|
||||
.height(ComponentConfig.WH_100_100)
|
||||
.width(ComponentConfig.WH_100_100)
|
||||
.borderRadius($r('app.float.radius_20'))
|
||||
.linearGradient(this.isTouched ? {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('app.color.DCEAF9'), 0.0], [$r('app.color.FAFAFA'), 1.0]]
|
||||
} : {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('sys.color.ohos_id_color_foreground_contrary'), 1],
|
||||
[$r('sys.color.ohos_id_color_foreground_contrary'), 1]]
|
||||
})
|
||||
.onTouch((event?: TouchEvent) => {
|
||||
if (event !== undefined) {
|
||||
if (event.type === TouchType.Down) {
|
||||
this.isTouched = true;
|
||||
}
|
||||
if (event.type === TouchType.Up) {
|
||||
this.isTouched = false;
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
.padding($r('app.float.distance_4'))
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.borderRadius($r('app.float.radius_24'))
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'));
|
||||
}
|
||||
}
|
55
application/src/main/ets/common/util/ConfigData.ts
Normal file
@ -0,0 +1,55 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export enum WidthPercent {
|
||||
WH_100_100 = '100%',
|
||||
WH_3_100 = '3%',
|
||||
WH_4_100 = '4%',
|
||||
WH_20_100 = '20%',
|
||||
WH_25_100 = '25%',
|
||||
WH_30_100 = '30%',
|
||||
WH_33_100 = '33%',
|
||||
WH_35_100 = '35%',
|
||||
WH_40_100 = '40%',
|
||||
WH_43_100 = '43%',
|
||||
WH_45_100 = '45%',
|
||||
WH_50_100 = '50%',
|
||||
WH_53_100 = '53%',
|
||||
WH_55_100 = '55%',
|
||||
WH_60_100 = '60%',
|
||||
WH_65_100 = '65%',
|
||||
WH_70_100 = '70%',
|
||||
WH_75_100 = '75%',
|
||||
WH_80_100 = '80%',
|
||||
WH_85_100 = '85%',
|
||||
WH_88_100 = '88%',
|
||||
WH_90_100 = '90%',
|
||||
WH_92_100 = '92%',
|
||||
WH_93_100 = '93%',
|
||||
WH_94_100 = '94%'
|
||||
};
|
||||
|
||||
export enum LocationChoice {
|
||||
SWITCH_BUTTON_X_OFFSET = '-4vp',
|
||||
DIALOG_DY_OFFSET = '-16vp'
|
||||
};
|
||||
|
||||
export enum ConfigValue {
|
||||
PWD_MAX_LENGTH = 64,
|
||||
ALIAS_MAX_LENGTH = 64,
|
||||
APP_AUTH_MAX_LENGTH = 4,
|
||||
REQUEST_AUTH_MAX_LENGTH = 5,
|
||||
VERTICAL_DIVIDER_WIDTH = 1
|
||||
};
|
53
application/src/main/ets/model/BundleModel.ets
Normal file
@ -0,0 +1,53 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import bundleManager from '@ohos.bundle.bundleManager';
|
||||
import bundleResManager from '@ohos.bundle.bundleResourceManager';
|
||||
import { CMModelErrorCode } from '../model/CertMangerModel';
|
||||
import { AppInfoVo } from './CertManagerVo/AppInfoVo';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
|
||||
const TAG = 'certManager BUNDLE:';
|
||||
|
||||
export class BundleNameModel {
|
||||
async getAppInfoList(appUid: number, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getAppInfoList enter uid: ' + appUid);
|
||||
try {
|
||||
let appInfo: AppInfoVo = {
|
||||
appImage: '',
|
||||
appName: '',
|
||||
};
|
||||
|
||||
let appBundleName = await bundleManager.getBundleNameByUid(appUid);
|
||||
console.log(TAG + 'appBundleName: ' + appBundleName);
|
||||
|
||||
let bundleFlags = bundleResManager.ResourceFlag.GET_RESOURCE_INFO_ALL;
|
||||
let resourceInfo = bundleResManager.getBundleResourceInfo(appBundleName, bundleFlags);
|
||||
appInfo.appName = resourceInfo.label;
|
||||
appInfo.appImage = resourceInfo.icon;
|
||||
console.log(TAG + 'get bundle info success');
|
||||
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, appInfo);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getAppInfoList failed, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let bundleNameModel = new BundleNameModel();
|
||||
|
||||
export default bundleNameModel as BundleNameModel;
|
28
application/src/main/ets/model/CertManagerVo/AppAuthorVo.ets
Normal file
@ -0,0 +1,28 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class AppAuthorVo {
|
||||
public appImage: string;
|
||||
public uid: string;
|
||||
public appName: string;
|
||||
public status: boolean;
|
||||
|
||||
constructor(appImage: string, uid: string, appName: string, status: boolean) {
|
||||
this.appImage = appImage;
|
||||
this.uid = uid;
|
||||
this.appName = appName;
|
||||
this.status = status;
|
||||
}
|
||||
}
|
19
application/src/main/ets/model/CertManagerVo/AppInfoVo.ets
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* Copyright (c) 2023-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class AppInfoVo {
|
||||
public appImage: string = '';
|
||||
public appName: string = '';
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class CertAbstractVo {
|
||||
public uri: string;
|
||||
public certAlias: string;
|
||||
public status: boolean;
|
||||
public subjectName: string;
|
||||
public subjectNameCN : string;
|
||||
|
||||
constructor(uri: string, certAlias: string, status: boolean, subjectName: string, subjectNameCN: string) {
|
||||
this.uri = uri;
|
||||
this.certAlias = certAlias;
|
||||
this.status = status;
|
||||
this.subjectName = subjectName;
|
||||
this.subjectNameCN = subjectNameCN;
|
||||
}
|
||||
}
|
75
application/src/main/ets/model/CertManagerVo/CertInfoVo.ets
Normal file
@ -0,0 +1,75 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class CertInfoVo {
|
||||
public uri: string;
|
||||
public certAlias: string;
|
||||
public status: boolean;
|
||||
public issuerName: string;
|
||||
public subjectName: string;
|
||||
public serial: string;
|
||||
public notBefore: string;
|
||||
public notAfter: string;
|
||||
public fingerprintSha256: string;
|
||||
public cert: Uint8Array;
|
||||
public subjectNameMap :Map<string, string>;
|
||||
public issuerNameMap :Map<string, string>;
|
||||
public dateMap :Map<string, string>;
|
||||
|
||||
constructor(
|
||||
uri: string,
|
||||
certAlias: string,
|
||||
status: boolean,
|
||||
issuerName: string,
|
||||
subjectName: string,
|
||||
serial: string,
|
||||
notBefore: string,
|
||||
notAfter: string,
|
||||
fingerprintSha256: string,
|
||||
cert: Uint8Array,
|
||||
subjectNameMap: Map<string, string>,
|
||||
issuerNameMap :Map<string, string>,
|
||||
dateMap :Map<string, string>) {
|
||||
this.uri = uri;
|
||||
this.certAlias = certAlias;
|
||||
this.status = status;
|
||||
this.issuerName = issuerName;
|
||||
this.subjectName = subjectName;
|
||||
this.serial = serial;
|
||||
this.notBefore = notBefore;
|
||||
this.notAfter = notAfter;
|
||||
this.fingerprintSha256 = fingerprintSha256;
|
||||
this.cert = cert;
|
||||
this.subjectNameMap = subjectNameMap;
|
||||
this.issuerNameMap = issuerNameMap;
|
||||
this.dateMap = dateMap;
|
||||
}
|
||||
|
||||
clearCertInfoVo(): void {
|
||||
this.uri = '';
|
||||
this.certAlias = '';
|
||||
this.status = false;
|
||||
this.issuerName = '';
|
||||
this.subjectName = '';
|
||||
this.serial = '';
|
||||
this.notBefore = '';
|
||||
this.notAfter = '';
|
||||
this.fingerprintSha256 = '';
|
||||
this.cert = new Uint8Array();
|
||||
this.subjectNameMap.clear();
|
||||
this.issuerNameMap.clear();
|
||||
this.dateMap.clear();
|
||||
}
|
||||
}
|
@ -0,0 +1,26 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class CredentialAbstractVo {
|
||||
public credType: string;
|
||||
public alias: string;
|
||||
public keyUri: string;
|
||||
|
||||
constructor(credType: string, alias: string, keyUri: string) {
|
||||
this.credType = credType;
|
||||
this.alias = alias;
|
||||
this.keyUri = keyUri;
|
||||
}
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class CredentialVo {
|
||||
public credType: string;
|
||||
public alias: string;
|
||||
public keyUri: string;
|
||||
public certNum: number;
|
||||
public keyNum: number;
|
||||
public credData: Uint8Array;
|
||||
|
||||
constructor(credType: string, alias: string, keyUri: string, certNum: number, keyNum: number, credData: Uint8Array) {
|
||||
this.credType = credType;
|
||||
this.alias = alias;
|
||||
this.keyUri = keyUri;
|
||||
this.certNum = certNum;
|
||||
this.keyNum = keyNum;
|
||||
this.credData = credData;
|
||||
}
|
||||
|
||||
clearCredentialVo(): void {
|
||||
this.credType = '';
|
||||
this.alias = '';
|
||||
this.keyUri = '';
|
||||
this.certNum = 0;
|
||||
this.keyNum = 0;
|
||||
this.credData = new Uint8Array();
|
||||
}
|
||||
}
|
@ -0,0 +1,32 @@
|
||||
/**
|
||||
* Copyright (c) 2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
export class RouterAppUidVo {
|
||||
public appUid: string;
|
||||
|
||||
constructor(appUid: string) {
|
||||
this.appUid = appUid;
|
||||
}
|
||||
}
|
||||
|
||||
export class RouterFileVo {
|
||||
public uri: string;
|
||||
public suffix: string;
|
||||
|
||||
constructor(uri: string, suffix: string) {
|
||||
this.uri = uri;
|
||||
this.suffix = suffix;
|
||||
}
|
||||
}
|
676
application/src/main/ets/model/CertMangerModel.ets
Normal file
@ -0,0 +1,676 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import { CertAbstractVo } from './CertManagerVo/CertAbstractVo';
|
||||
import { CertInfoVo } from './CertManagerVo/CertInfoVo';
|
||||
import { CredentialAbstractVo } from './CertManagerVo/CredentialAbstractVo';
|
||||
import { CredentialVo } from './CertManagerVo/CredentialVo';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
import CertManager from '@ohos.security.certManager';
|
||||
|
||||
const TAG = 'CertManager Model: ';
|
||||
|
||||
export enum CMModelErrorCode {
|
||||
CM_MODEL_ERROR_SUCCESS = 0,
|
||||
CM_MODEL_ERROR_FAILED = -1,
|
||||
CM_MODEL_ERROR_EXCEPTION = -2,
|
||||
CM_MODEL_ERROR_UNKNOWN_OPT = -3,
|
||||
CM_MODEL_ERROR_NOT_SUPPORT = -4,
|
||||
}
|
||||
|
||||
export enum CMModelOptType {
|
||||
CM_MODEL_OPT_UNKNOWN = 0,
|
||||
CM_MODEL_OPT_SYSTEM_CA = 1,
|
||||
CM_MODEL_OPT_USER_CA = 2,
|
||||
CM_MODEL_OPT_APP_CRED = 3,
|
||||
CM_MODEL_OPT_PRIVATE_CRED = 4,
|
||||
}
|
||||
|
||||
export enum CertManagerStore {
|
||||
/* credential certificate store for end entity certificates. */
|
||||
CERT_MANAGER_CREDENTIAL_STORE = 0,
|
||||
/* read only, updated by system only. */
|
||||
CERT_MANAGER_SYSTEM_TRUSTED_STORE = 1,
|
||||
/* modifiable by applications and user. */
|
||||
CERT_MANAGER_USER_TRUSTED_STORE = 2,
|
||||
/* application specific trusted certificate store; modifiable by the application only. */
|
||||
CERT_MANAGER_APPLICATION_TRUSTED_STORE = 3,
|
||||
}
|
||||
|
||||
export class CertMangerModel {
|
||||
getCertOrCredList(optType: CMModelOptType, callback: Function): void {
|
||||
console.log(TAG + 'getCertOrCredList start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
this.getSystemTrustedCertificateList((errCode:CMModelErrorCode, certList: Array<CertAbstractVo>) => {
|
||||
callback(errCode, certList);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.getUserTrustedCertificateList((errCode: CMModelErrorCode, certList: Array<CertAbstractVo>) => {
|
||||
callback(errCode, certList);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.getAppCredList((errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
callback(errCode, credList);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
this.getPrivateCredList((errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
callback(errCode, credList);
|
||||
});
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT, undefined);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
getCertOrCred(optType: CMModelOptType, uri: string, callback: Function): void {
|
||||
console.log(TAG + 'getCertOrCred start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
this.getSystemTrustedCertificate(uri, (errCode: CMModelErrorCode, certInfo: CertInfoVo) => {
|
||||
console.info('getSystemTrustedCertificate certInfo is' + JSON.stringify(certInfo));
|
||||
callback(errCode, certInfo);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.getUserTrustedCertificate(uri, (errCode: CMModelErrorCode, certInfo: CertInfoVo) => {
|
||||
callback(errCode, certInfo);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.getAppCredential(uri, (errCode: CMModelErrorCode, credInfo: CredentialVo) => {
|
||||
callback(errCode, credInfo);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
this.getPrivateCred(uri, (errCode: CMModelErrorCode, credInfo: CredentialVo) => {
|
||||
callback(errCode, credInfo);
|
||||
});
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT, undefined);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
deleteCertOrCred(optType: CMModelOptType, uri: string, callback: Function): void {
|
||||
console.log(TAG + 'deleteCertOrCred start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.deleteUserTrustedCertificate(uri, (errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.deleteAppCredential(uri, (errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
setCertStatus(optType: CMModelOptType, uri: string, status: boolean, callback: Function): void {
|
||||
console.log(TAG + 'setCertStatus start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.setCertificateStatus(uri, CertManagerStore.CERT_MANAGER_USER_TRUSTED_STORE, status,
|
||||
(errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
this.setCertificateStatus(uri, CertManagerStore.CERT_MANAGER_SYSTEM_TRUSTED_STORE, status,
|
||||
(errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
delAllCertOrCred(optType: CMModelOptType, callback: Function): void {
|
||||
console.log(TAG + 'delAllCertOrCred start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.delAllUserCertificate((errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.delAllAppCredential((errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
getAuthAppList(optType: CMModelOptType, uri: string, callback: Function): void {
|
||||
console.log(TAG + 'getAuthAppList start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.getAuthorizedAppList(uri, (errCode: CMModelErrorCode, appUidList: Array<string>) => {
|
||||
callback(errCode, appUidList);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
setAppAuthPromise(optType: CMModelOptType, uri: string, appUid: string, status: boolean): Promise<void> {
|
||||
console.log(TAG + 'setAppAuth start');
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
return new Promise((resolve, reject)=>{
|
||||
this.setAuthorizedAppStatus(uri, appUid, status, (errCode: CMModelErrorCode, data: string) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
resolve(void(data));
|
||||
} else {
|
||||
reject(errCode);
|
||||
}
|
||||
});
|
||||
});
|
||||
default:
|
||||
return new Promise((resolve, reject) => {
|
||||
reject(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
setAppAuth(optType: CMModelOptType, uri: string, appUid: string, status: boolean, callback: Function): void {
|
||||
console.log(TAG + 'setAppAuth start');
|
||||
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.setAuthorizedAppStatus(uri, appUid, status, (errCode: CMModelErrorCode, data: string) => {
|
||||
callback(errCode, data);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
installCertOrCred(optType: CMModelOptType, alias: string, data: Uint8Array, pwd: string, callback: Function): void {
|
||||
console.log(TAG + 'installCertOrCred start');
|
||||
console.info(TAG + 'installCert optType: ' + optType + ',alias: ' + alias);
|
||||
switch (optType) {
|
||||
case CMModelOptType.CM_MODEL_OPT_USER_CA:
|
||||
this.installUserCertificate(data, alias, (errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_APP_CRED:
|
||||
this.installAppCertificate(data, alias, pwd, (errCode: CMModelErrorCode) => {
|
||||
callback(errCode);
|
||||
});
|
||||
break;
|
||||
case CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED:
|
||||
case CMModelOptType.CM_MODEL_OPT_SYSTEM_CA:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_NOT_SUPPORT);
|
||||
break;
|
||||
default:
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_UNKNOWN_OPT);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private async getSystemTrustedCertificateList(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getSystemTrustedCertificateList start');
|
||||
try {
|
||||
let subjectNameCN: string = '';
|
||||
let result = await CertManager.getSystemTrustedCertificateList();
|
||||
let certList: CertAbstractVo[] = [];
|
||||
let regex: RegExp = new RegExp('(?<=CN=).*?(?=,)', 'g');
|
||||
if (result.certList !== undefined) {
|
||||
console.log(TAG + 'certManager::getSystemTrustedCertificateList result: ' + JSON.stringify(result));
|
||||
for (let i = 0; i < result.certList.length; i++) {
|
||||
if (result.certList[i].subjectName.length !== 0) {
|
||||
let temp = result.certList[i].subjectName.match(regex);
|
||||
subjectNameCN = (temp !== undefined) ? String(temp) : '';
|
||||
console.info('subjectNameCN is:' + subjectNameCN);
|
||||
}
|
||||
certList.push(new CertAbstractVo(String(result.certList[i].uri), String(result.certList[i].certAlias),
|
||||
Boolean(result.certList[i].status), String(result.certList[i].subjectName), String(subjectNameCN)));
|
||||
}
|
||||
console.log(TAG + 'getSystemTrustedCertificateList end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, certList);
|
||||
} else {
|
||||
console.error(TAG + 'getSystemTrustedCertificateList failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getSystemTrustedCertificateList err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async getSystemTrustedCertificate(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getSystemTrustedCertificate start');
|
||||
try {
|
||||
let result = await CertManager.getSystemTrustedCertificate(certUri);
|
||||
let subjectNameMap: Map<string, string> = new Map();
|
||||
let issuerNameMap: Map<string, string> = new Map();
|
||||
let dateMap: Map<string, string> = new Map();
|
||||
let regex1: RegExp = new RegExp('(?<=CN=).*?(?=,)', 'g');
|
||||
let regex2: RegExp = new RegExp('(?<=OU=).*?(?=,)', 'g');
|
||||
let regex3: RegExp = new RegExp('(?<=O=).*', 'g');
|
||||
|
||||
if (result.certInfo !== undefined) {
|
||||
if (result.certInfo.subjectName.length !== 0) {
|
||||
let subjectNameCN = result.certInfo.subjectName.match(regex1);
|
||||
console.info('subjectNameCN is:' + subjectNameCN);
|
||||
let subjectNameOU = result.certInfo.subjectName.match(regex2);
|
||||
console.info('subjectNameOU is:' + subjectNameOU);
|
||||
let subjectNameO = result.certInfo.subjectName.match(regex3);
|
||||
console.info('subjectNameO is:' + subjectNameO);
|
||||
subjectNameMap.set('常用名称:', String(subjectNameCN));
|
||||
subjectNameMap.set('组织:', String(subjectNameO));
|
||||
subjectNameMap.set('组织单位:', String(subjectNameOU));
|
||||
subjectNameMap.set('序列号:', String(result.certInfo.serial));
|
||||
}
|
||||
if (result.certInfo.issuerName.length !== 0) {
|
||||
let issuerNameCN = result.certInfo.issuerName.match(regex1);
|
||||
console.info('issuerNameCN is:' + issuerNameCN);
|
||||
let issuerNameOU = result.certInfo.issuerName.match(regex2);
|
||||
console.info('issuerNameOU is:' + issuerNameOU);
|
||||
let issuerNameO = result.certInfo.issuerName.match(regex3);
|
||||
console.info('issuerNameO is:' + issuerNameO);
|
||||
issuerNameMap.set('常用名称:', String(issuerNameCN));
|
||||
issuerNameMap.set('组织:', String(issuerNameO));
|
||||
issuerNameMap.set('组织单位:', String(issuerNameOU));
|
||||
}
|
||||
dateMap.set('颁发时间:', String(result.certInfo.notBefore));
|
||||
dateMap.set('有效期至:', String(result.certInfo.notAfter));
|
||||
|
||||
let certData: Uint8Array = result.certInfo.cert;
|
||||
let certInfo = new CertInfoVo(String(result.certInfo.uri), String(result.certInfo.certAlias),
|
||||
Boolean(result.certInfo.status), String(result.certInfo.issuerName), String(result.certInfo.subjectName),
|
||||
String(result.certInfo.serial), String(result.certInfo.notBefore),
|
||||
String(result.certInfo.notAfter), String(result.certInfo.fingerprintSha256),
|
||||
certData, subjectNameMap, issuerNameMap, dateMap);
|
||||
console.log(TAG + 'getSystemTrustedCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, certInfo);
|
||||
} else {
|
||||
console.error(TAG + 'getSystemTrustedCertificate failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getSystemTrustedCertificate err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async getUserTrustedCertificateList(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getUserTrustedCertificateList start');
|
||||
try {
|
||||
let subjectNameCN: string = '';
|
||||
let result = await CertManager.getUserTrustedCertificateList();
|
||||
let certList: CertAbstractVo[] = [];
|
||||
let regex: RegExp = new RegExp('(?<=CN=).*?(?=,)', 'g');
|
||||
if (result.certList !== undefined) {
|
||||
console.log(TAG + 'getUserTrustedCertificateList result: ' + JSON.stringify(result));
|
||||
for (let i = 0; i < result.certList.length; i++) {
|
||||
if (result.certList[i].subjectName.length !== 0) {
|
||||
let temp = result.certList[i].subjectName.match(regex);
|
||||
subjectNameCN = (temp !== undefined) ? String(temp) : '';
|
||||
console.info('subjectNameCN is:' + subjectNameCN);
|
||||
}
|
||||
if (String(result.certList[i].uri).indexOf('u=0;') === -1) {
|
||||
certList.push(new CertAbstractVo(String(result.certList[i].uri), String(result.certList[i].certAlias),
|
||||
Boolean(result.certList[i].status), String(result.certList[i].subjectName), String(subjectNameCN)));
|
||||
}
|
||||
}
|
||||
console.log(TAG + 'getUserTrustedCertificateList end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, certList);
|
||||
} else {
|
||||
console.error(TAG + 'getUserTrustedCertificateList failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getUserTrustedCertificateList err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getUserTrustedCertificate(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getUserTrustedCertificate start');
|
||||
try {
|
||||
let result = await CertManager.getUserTrustedCertificate(certUri);
|
||||
let subjectNameMap: Map<string, string> = new Map();
|
||||
let issuerNameMap: Map<string, string> = new Map();
|
||||
let dateMap: Map<string, string> = new Map();
|
||||
let regex1: RegExp = new RegExp('(?<=CN=).*?(?=,)', 'g');
|
||||
let regex2: RegExp = new RegExp('(?<=OU=).*?(?=,)', 'g');
|
||||
let regex3: RegExp = new RegExp('(?<=O=).*', 'g');
|
||||
|
||||
if (result.certInfo !== undefined) {
|
||||
if (result.certInfo.subjectName.length !== 0) {
|
||||
let subjectNameCN = result.certInfo.subjectName.match(regex1);
|
||||
console.info('subjectNameCN is:' + subjectNameCN);
|
||||
let subjectNameOU = result.certInfo.subjectName.match(regex2);
|
||||
console.info('subjectNameOU is:' + subjectNameOU);
|
||||
let subjectNameO = result.certInfo.subjectName.match(regex3);
|
||||
console.info('SubjectNameO is:' + subjectNameO);
|
||||
subjectNameMap.set('常用名称:', String(subjectNameCN));
|
||||
subjectNameMap.set('组织:', String(subjectNameO));
|
||||
subjectNameMap.set('组织单位:', String(subjectNameOU));
|
||||
subjectNameMap.set('序列号:', String(result.certInfo.serial));
|
||||
}
|
||||
if (result.certInfo.issuerName.length !== 0) {
|
||||
let issuerNameCN = result.certInfo.issuerName.match(regex1);
|
||||
console.info('issuerNameCN is:' + issuerNameCN);
|
||||
let issuerNameOU = result.certInfo.issuerName.match(regex2);
|
||||
console.info('issuerNameOU is:' + issuerNameOU);
|
||||
let issuerNameO = result.certInfo.issuerName.match(regex3);
|
||||
console.info('issuerNameO is:' + issuerNameO);
|
||||
issuerNameMap.set('常用名称:', String(issuerNameCN));
|
||||
issuerNameMap.set('组织:', String(issuerNameO));
|
||||
issuerNameMap.set('组织单位:', String(issuerNameOU));
|
||||
}
|
||||
dateMap.set('颁发时间:', String(result.certInfo.notBefore));
|
||||
dateMap.set('有效期至:', String(result.certInfo.notAfter));
|
||||
let certData:Uint8Array = result.certInfo.cert;
|
||||
let certInfo = new CertInfoVo(String(result.certInfo.uri), String(result.certInfo.certAlias),
|
||||
Boolean(result.certInfo.status), String(result.certInfo.issuerName), String(result.certInfo.subjectName),
|
||||
String(result.certInfo.serial), String(result.certInfo.notBefore),
|
||||
String(result.certInfo.notAfter), String(result.certInfo.fingerprintSha256),
|
||||
certData, subjectNameMap, issuerNameMap, dateMap);
|
||||
console.log(TAG + 'getUserTrustedCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, certInfo);
|
||||
} else {
|
||||
console.error(TAG + 'getUserTrustedCertificate failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getUserTrustedCertificate err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async deleteUserTrustedCertificate(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'deleteUserTrustedCertificate start');
|
||||
try {
|
||||
await CertManager.uninstallUserTrustedCertificate(certUri);
|
||||
console.log(TAG + 'deleteUserTrustedCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'deleteUserTrustedCertificate err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async setCertificateStatus(certUri: string, store: number,
|
||||
status: boolean, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'setCertificateStatus start');
|
||||
try {
|
||||
await CertManager.setCertificateStatus(certUri, store, status);
|
||||
console.log(TAG + 'setCertificateStatus end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'setCertificateStatus failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getAppCredList(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getAppCredList start');
|
||||
|
||||
try {
|
||||
let result = await CertManager.getAppCertificateList();
|
||||
let credList: CredentialAbstractVo[] = [];
|
||||
if (result.credentialList !== undefined) {
|
||||
for (let i = 0; i < result.credentialList.length; i++) {
|
||||
credList.push(new CredentialAbstractVo(String(result.credentialList[i].type),
|
||||
String(result.credentialList[i].alias), String(result.credentialList[i].keyUri)));
|
||||
}
|
||||
console.log(TAG + 'getAppCredList end credList: ' + JSON.stringify(credList));
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, credList);
|
||||
} else {
|
||||
console.error(TAG + 'getAppCredList failed, undefined.');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getAppCredList failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getAppCredential(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getAppCredential start');
|
||||
try {
|
||||
let result = await CertManager.getAppCertificate(certUri);
|
||||
if (result.credential !== undefined) {
|
||||
let certData:Uint8Array = result.credential.credData;
|
||||
let credInfo = new CredentialVo(String(result.credential.type), String(result.credential.alias),
|
||||
String(result.credential.keyUri), Number(result.credential.certNum),
|
||||
Number(result.credential.keyNum), certData);
|
||||
console.log(TAG + 'getAppCredential end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, credInfo);
|
||||
} else {
|
||||
console.error(TAG + 'getAppCredential failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getAppCredential failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async deleteAppCredential(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'deleteAppCredential start');
|
||||
try {
|
||||
await CertManager.uninstallAppCertificate(certUri);
|
||||
console.log(TAG + 'deleteAppCredential end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'deleteAppCredential failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getPrivateCredList(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getPrivateCredList start');
|
||||
|
||||
try {
|
||||
let result = await CertManager.getPrivateCertificateList();
|
||||
let credList: CredentialAbstractVo[] = [];
|
||||
if (result.credentialList !== undefined) {
|
||||
for (let i = 0; i < result.credentialList.length; i++) {
|
||||
credList.push(new CredentialAbstractVo(String(result.credentialList[i].type),
|
||||
String(result.credentialList[i].alias), String(result.credentialList[i].keyUri)));
|
||||
}
|
||||
console.log(TAG + 'getPrivateCredList end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, credList);
|
||||
} else {
|
||||
console.error(TAG + 'getPrivateCredList failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_FAILED);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getPrivateCredList failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getPrivateCred(certUri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getPrivateCred start');
|
||||
try {
|
||||
let result = await CertManager.getPrivateCertificate(String(certUri));
|
||||
if (result.credential !== undefined) {
|
||||
let certData:Uint8Array = result.credential.credData;
|
||||
let credInfo = new CredentialVo(String(result.credential.type), String(result.credential.alias),
|
||||
String(result.credential.keyUri), Number(result.credential.certNum),
|
||||
Number(result.credential.keyNum), certData);
|
||||
console.log(TAG + 'getPrivateCred end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, credInfo);
|
||||
} else {
|
||||
console.error(TAG + 'getPrivateCred failed, undefined');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getPrivateCred failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async delAllUserCertificate(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'delAllUserCertificate start');
|
||||
try {
|
||||
await CertManager.uninstallAllUserTrustedCertificate();
|
||||
console.log(TAG + 'delAllUserCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'delAllUserCertificate failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async delAllAppCredential(callback: Function): Promise<void> {
|
||||
console.log(TAG + 'delAllAppCredential start');
|
||||
try {
|
||||
await CertManager.uninstallAllAppCertificate();
|
||||
console.log(TAG + 'delAllAppCredential end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'delAllAppCredential failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async getAuthorizedAppList(uri: string, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'getAuthorizedAppList start');
|
||||
try {
|
||||
let result = await CertManager.getAuthorizedAppList(uri);
|
||||
console.log(TAG + 'getAuthorizedAppList end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, result.appUidList);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'getAuthorizedAppList failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
private async setAuthorizedAppStatus(uri: string, appUid: string,
|
||||
status: boolean, callback: Function): Promise<void> {
|
||||
console.log(TAG + 'setAuthorizedAppStatus start');
|
||||
try {
|
||||
if (status) {
|
||||
let result = await CertManager.grantAppCertificate(uri, appUid);
|
||||
console.log(TAG + 'setAuthorizedAppStatus true end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS, result.uri);
|
||||
} else {
|
||||
console.log(TAG + 'appId:' + appUid + 'uri:' + uri);
|
||||
await CertManager.removeGrantedAppCertificate(uri, appUid);
|
||||
console.log(TAG + 'setAuthorizedAppStatus false end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
}
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'setAuthorizedAppStatus failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async installUserCertificate(data: Uint8Array, alias: string, callback: Function): Promise<void> {
|
||||
console.info(TAG + 'installUserCertificate start alias: ' + alias + 'data' + JSON.stringify(data));
|
||||
try {
|
||||
await CertManager.installUserTrustedCertificate({
|
||||
inData: data,
|
||||
alias: alias
|
||||
});
|
||||
|
||||
console.info(TAG + 'installUserCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'installUserCertificate failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
private async installAppCertificate(data: Uint8Array, alias: string,
|
||||
pwd: string, callback: Function): Promise<void> {
|
||||
console.info(TAG + 'installAppCertificate start');
|
||||
try {
|
||||
await CertManager.installAppCertificate(data, pwd, alias);
|
||||
console.info(TAG + 'installAppCertificate end');
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_SUCCESS);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'installAppCertificate failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(CMModelErrorCode.CM_MODEL_ERROR_EXCEPTION);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
let certMangerModel = new CertMangerModel();
|
||||
|
||||
export default certMangerModel as CertMangerModel;
|
54
application/src/main/ets/model/FileIoModel.ets
Normal file
@ -0,0 +1,54 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import fileUri from '@ohos.file.fileuri';
|
||||
import fs from '@ohos.file.fs';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
|
||||
export class FileIoModel {
|
||||
getMediaFileData(mediaUri: string, callback: Function): void {
|
||||
console.log('CertManager FA getMediaFile start');
|
||||
try {
|
||||
let file = fs.openSync(mediaUri, fs.OpenMode.READ_ONLY);
|
||||
let stat = fs.statSync(file.fd);
|
||||
let buf = new ArrayBuffer(Number(stat.size));
|
||||
let num = fs.readSync(file.fd, buf);
|
||||
fs.closeSync(file.fd);
|
||||
console.log('CertManager FA getMediaFile success');
|
||||
callback(new Uint8Array(buf));
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error('CertManager FA getMediaFileData failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(undefined);
|
||||
}
|
||||
}
|
||||
|
||||
getMediaFileSuffix(mediaUri: string, callback: Function): void {
|
||||
try {
|
||||
console.log('CertManager FA getMediaFileSuffix start uri: ' + mediaUri);
|
||||
let uri = new fileUri.FileUri(mediaUri);
|
||||
let suffix = uri.name.substring(uri.name.lastIndexOf('.') + 1);
|
||||
callback(suffix);
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error('CertManager FA getMediaFileSuffix failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
callback(undefined);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let fileIoModel = new FileIoModel();
|
||||
|
||||
export default fileIoModel as FileIoModel;
|
17
application/src/main/ets/pages/Index.ets
Normal file
@ -0,0 +1,17 @@
|
||||
@Entry
|
||||
@Component
|
||||
struct Index {
|
||||
@State message: string = 'Hello World';
|
||||
|
||||
build() {
|
||||
Row() {
|
||||
Column() {
|
||||
Text(this.message)
|
||||
.fontSize(50)
|
||||
.fontWeight(FontWeight.Bold)
|
||||
}
|
||||
.width('100%')
|
||||
}
|
||||
.height('100%')
|
||||
}
|
||||
}
|
1013
application/src/main/ets/pages/cerEvidenceFa.ets
Normal file
159
application/src/main/ets/pages/certInstallAliasInput.ets
Normal file
@ -0,0 +1,159 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import HeadComponent from '../common/component/headComponent';
|
||||
import { WidthPercent, LocationChoice, ConfigValue } from '../common/util/ConfigData';
|
||||
import router from '@ohos.router';
|
||||
import CmInstallPresenter from '../presenter/CmInstallPresenter';
|
||||
import CmFaPresenter from '../presenter/CmFaPresenter';
|
||||
import { GlobalContext } from '../common/GlobalContext';
|
||||
import { RouterFileVo } from '../model/CertManagerVo/RouterInfoVo';
|
||||
|
||||
@Entry
|
||||
@Component
|
||||
struct CertInstallAliasInput {
|
||||
@State mAppCredAuthPresenter: CmInstallPresenter = CmInstallPresenter.getInstance();
|
||||
@State mFaPresenter: CmFaPresenter = CmFaPresenter.getInstance();
|
||||
@State certAlias: string = '';
|
||||
|
||||
onPageShow() {
|
||||
let uri = GlobalContext.getContext().getAbilityWant().uri;
|
||||
GlobalContext.getContext().clearAbilityWantUri();
|
||||
|
||||
if (uri === 'certInstall') {
|
||||
this.mFaPresenter.startInstall();
|
||||
} else if (uri === 'requestAuthorize') {
|
||||
this.mFaPresenter.startRequestAuth(GlobalContext.getContext().getAbilityWant().parameters?.appUid as string);
|
||||
}
|
||||
}
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
Column() {
|
||||
HeadComponent({ headName: $r('app.string.certificateAliasTab') });
|
||||
Text($r('app.string.certificateAliasInfo'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({
|
||||
top: $r('app.float.distance_24'),
|
||||
left: $r('app.float.distance_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
|
||||
TextInput()
|
||||
.type(InputType.Normal)
|
||||
.backgroundColor($r('sys.color.ohos_id_color_sub_background'))
|
||||
.enterKeyType(EnterKeyType.Done)
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.onChange((value: string) => {
|
||||
this.certAlias = value;
|
||||
})
|
||||
.maxLength(ConfigValue.ALIAS_MAX_LENGTH)
|
||||
.margin({
|
||||
left: $r('app.float.distance_24'),
|
||||
right: $r('app.float.distance_24')
|
||||
})
|
||||
.height($r('app.float.distance_48'))
|
||||
|
||||
Row() {
|
||||
Divider().color($r('app.color.CertManager_Divider_Color_182431'))
|
||||
}
|
||||
.margin({
|
||||
left: $r('app.float.distance_24'),
|
||||
right: $r('app.float.distance_24'),
|
||||
})
|
||||
|
||||
Text($r('app.string.installAliasInputInfo'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontWeight(FontWeight.Regular)
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body2'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_24'),
|
||||
top: $r('app.float.distance_16')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
.opacity($r('app.float.opacity_100_60'))
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_75_100);
|
||||
|
||||
Column() {
|
||||
Row() {
|
||||
Button() {
|
||||
Text($r('app.string.installAliasInputCancel'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('sys.color.ohos_id_color_text_hyperlink'))
|
||||
}
|
||||
.type(ButtonType.Capsule)
|
||||
.backgroundColor($r('app.color.install_cancel_bt_bg_color'))
|
||||
.width($r('app.float.component_button_width_phone'))
|
||||
.height($r('app.float.application_button_height'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_24'),
|
||||
})
|
||||
.onClick(() => {
|
||||
router.back();
|
||||
})
|
||||
|
||||
if ((this.certAlias.length > 0) && (this.certAlias[0] != ' ')) {
|
||||
Button() {
|
||||
Text($r('app.string.installAliasInputConfirm'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('app.color.install_confirm_bt_font_color'))
|
||||
}
|
||||
.type(ButtonType.Capsule)
|
||||
.backgroundColor($r('app.color.install_confirm_bt_bg_color'))
|
||||
.width($r('app.float.component_button_width_phone'))
|
||||
.height($r('app.float.application_button_height'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_16'),
|
||||
right: $r('app.float.distance_24'),
|
||||
})
|
||||
.onClick(() => {
|
||||
let fileInfo: RouterFileVo = router.getParams() as RouterFileVo;
|
||||
this.mAppCredAuthPresenter.installCert(fileInfo.uri, this.certAlias, fileInfo.suffix);
|
||||
})
|
||||
} else {
|
||||
Button() {
|
||||
Text($r('app.string.installAliasInputConfirm'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('app.color.install_confirm_bt_font_color'))
|
||||
}
|
||||
.type(ButtonType.Capsule)
|
||||
.backgroundColor($r('app.color.install_confirm_bt_bg_disable_color'))
|
||||
.width($r('app.float.component_button_width_phone'))
|
||||
.height($r('app.float.application_button_height'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_16'),
|
||||
right: $r('app.float.distance_24'),
|
||||
})
|
||||
}
|
||||
}
|
||||
.margin({ bottom: $r('app.float.wh_value_24') })
|
||||
}
|
||||
.justifyContent(FlexAlign.End)
|
||||
.height(WidthPercent.WH_25_100);
|
||||
}
|
||||
.backgroundColor($r('sys.color.ohos_id_color_sub_background'))
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100);
|
||||
}
|
||||
}
|
347
application/src/main/ets/pages/certManagerFa.ets
Normal file
@ -0,0 +1,347 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import { WidthPercent, LocationChoice, ConfigValue } from '../common/util/ConfigData';
|
||||
import HeadComponent from '../common/component/headComponent';
|
||||
import { SubEntryComponent } from '../common/component/subEntryComponent';
|
||||
import CmFaPresenter from '../presenter/CmFaPresenter';
|
||||
import { GlobalContext } from '../common/GlobalContext';
|
||||
|
||||
class CertListItem {
|
||||
public targetPage: string = '';
|
||||
public title: Resource = $r('app.string.trustedEvidence');
|
||||
};
|
||||
|
||||
@Entry
|
||||
@Component
|
||||
struct CertificateComponent {
|
||||
@State touchedItem: boolean = false;
|
||||
@State columnMargin: string = '12vp';
|
||||
@State mFaPresenter: CmFaPresenter = CmFaPresenter.getInstance();
|
||||
private listItems: Array<CertListItem> = [
|
||||
{ targetPage: 'pages/trustedCa', title: $r('app.string.trustedEvidence') },
|
||||
{ targetPage: 'pages/cerEvidenceFa', title: $r('app.string.userEvidence') }
|
||||
];
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
GridContainer({
|
||||
columns: 12,
|
||||
sizeType: SizeType.Auto,
|
||||
gutter: vp2px(1) === 2 ? '12vp' : '0vp',
|
||||
margin: vp2px(1) === 2 ? '24vp' : '0vp'
|
||||
}) {
|
||||
Row({}) {
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 0 }, sm: { span: 0, offset: 0 },
|
||||
md: { span: 0, offset: 0 }, lg: { span: 2, offset: 0 }
|
||||
});
|
||||
|
||||
Column({ space: this.columnMargin }) {
|
||||
HeadComponent({ headName: $r('app.string.certificateTab') })
|
||||
Column({ space: this.columnMargin }) {
|
||||
List() {
|
||||
ForEach(this.listItems, (item: CertListItem) => {
|
||||
ListItem() {
|
||||
SubEntryComponent({ targetPage: item.targetPage, title: item.title })
|
||||
}
|
||||
}, (item: CertListItem) => JSON.stringify(item))
|
||||
}
|
||||
.padding($r('app.float.wh_value_4'))
|
||||
.divider({
|
||||
strokeWidth: $r('app.float.sys_list_divider_strokeWidth_value'),
|
||||
color: $r('app.color.sys_list_divider_color_000000'),
|
||||
startMargin: '8vp',
|
||||
endMargin: '8vp'
|
||||
})
|
||||
.borderRadius($r('app.float.user_list_divider_borderRadius_value'))
|
||||
.backgroundColor($r('app.color.user_list_backgroundColor_FFFFFF'))
|
||||
|
||||
CertInstallComponent({ mFaPresenter: $mFaPresenter })
|
||||
|
||||
DeleteAll({ mFaPresenter: $mFaPresenter })
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
}
|
||||
.backgroundColor($r('sys.color.ohos_id_color_sub_background'))
|
||||
.padding({ left: $r('app.float.wh_value_12'), right: $r('app.float.wh_value_12') })
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 12, offset: 0 }, sm: { span: 12, offset: 0 },
|
||||
md: { span: 12, offset: 0 }, lg: { span: 8, offset: 2 }
|
||||
});
|
||||
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 12 }, sm: { span: 0, offset: 12 },
|
||||
md: { span: 0, offset: 12 }, lg: { span: 2, offset: 10 }
|
||||
})
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100);
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100);
|
||||
}
|
||||
.backgroundColor($r('sys.color.ohos_id_color_sub_background'))
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100);
|
||||
}
|
||||
|
||||
onPageShow() {
|
||||
let uri = GlobalContext.getContext().getAbilityWant().uri;
|
||||
GlobalContext.getContext().clearAbilityWantUri();
|
||||
|
||||
if (uri === 'certInstall') {
|
||||
this.mFaPresenter.startInstall();
|
||||
} else if (uri === 'requestAuthorize') {
|
||||
this.mFaPresenter.startRequestAuth(GlobalContext.getContext().getAbilityWant().parameters?.appUid as string);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@CustomDialog
|
||||
@Component
|
||||
struct CustomDialogExampleDeleteAll {
|
||||
controller?: CustomDialogController;
|
||||
@Link deleteAll: CmFaPresenter;
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
GridContainer({
|
||||
columns: 12,
|
||||
sizeType: SizeType.Auto,
|
||||
gutter: vp2px(1) === 2 ? '12vp' : '0vp',
|
||||
margin: vp2px(1) === 2 ? '24vp' : '0vp'
|
||||
}) {
|
||||
Row({}) {
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 0 }, sm: { span: 0, offset: 0 },
|
||||
md: { span: 0, offset: 0 }, lg: { span: 2, offset: 0 }
|
||||
});
|
||||
|
||||
Column() {
|
||||
Text($r('app.string.deleteAllCredDialogTitle'))
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_dialog_tittle'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
Text($r('app.string.deleteAllCredDialogMessage'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Regular)
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.margin({
|
||||
top: $r('app.float.wh_value_16'),
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
|
||||
Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center,
|
||||
justifyContent: FlexAlign.SpaceAround }) {
|
||||
Button($r('app.string.deleteAllCredCancel'))
|
||||
.onClick(() => {
|
||||
if (this.controller !== undefined) {
|
||||
this.controller.close()
|
||||
}
|
||||
})
|
||||
.backgroundColor($r('app.color.credentials_app_finish_backgroundColor'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_button1'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_hyperlink'))
|
||||
.width($r('app.float.wh_value_152'))
|
||||
.height($r('app.float.wh_value_40'))
|
||||
Divider()
|
||||
.strokeWidth(ConfigValue.VERTICAL_DIVIDER_WIDTH)
|
||||
.color($r('sys.color.ohos_id_color_list_separator'))
|
||||
.vertical(true)
|
||||
.height($r('app.float.wh_value_40'))
|
||||
.opacity($r('app.float.opacity_0_2'))
|
||||
Button($r('app.string.deleteAllCredDelete'))
|
||||
.onClick(() => {
|
||||
this.deleteAll.uninstallAllCert();
|
||||
if (this.controller !== undefined) {
|
||||
this.controller.close()
|
||||
}
|
||||
})
|
||||
.backgroundColor($r('app.color.credentials_app_finish_backgroundColor'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_button1'))
|
||||
.fontColor($r('sys.color.ohos_id_color_warning'))
|
||||
.width($r('app.float.wh_value_152'))
|
||||
.height($r('app.float.wh_value_40'))
|
||||
}
|
||||
.height($r('app.float.wh_value_64'))
|
||||
.padding({
|
||||
bottom: $r('app.float.wh_value_16')
|
||||
})
|
||||
.margin({
|
||||
top: $r('app.float.wh_value_16'),
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.borderRadius($r('app.float.user_list_divider_borderRadius_value'))
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'))
|
||||
.useSizeType({
|
||||
xs: { span: 12, offset: 0 }, sm: { span: 12, offset: 0 },
|
||||
md: { span: 12, offset: 0 }, lg: { span: 8, offset: 2 }
|
||||
});
|
||||
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 12 }, sm: { span: 0, offset: 12 },
|
||||
md: { span: 0, offset: 12 }, lg: { span: 2, offset: 10 }
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
.margin({
|
||||
bottom: $r('sys.float.ohos_id_dialog_margin_bottom'),
|
||||
left: $r('sys.float.ohos_id_dialog_margin_start'),
|
||||
right: $r('sys.float.ohos_id_dialog_margin_end'),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@Component
|
||||
struct DeleteAll {
|
||||
@State isTouched: boolean = false;
|
||||
@Link mFaPresenter: CmFaPresenter;
|
||||
deleteWarnDialog: CustomDialogController = new CustomDialogController({
|
||||
builder: CustomDialogExampleDeleteAll({ deleteAll: $mFaPresenter }),
|
||||
autoCancel: true,
|
||||
customStyle: true,
|
||||
alignment: DialogAlignment.Bottom,
|
||||
})
|
||||
|
||||
build() {
|
||||
Row() {
|
||||
Text($r('app.string.deleteAllCred'))
|
||||
.fontSize($r('app.float.font_16'))
|
||||
.lineHeight($r('app.float.wh_value_22'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('app.color.cm_del_all_font_color'))
|
||||
.padding({ left: $r('app.float.distance_8') })
|
||||
.linearGradient(this.isTouched ? {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('app.color.DCEAF9'), 0.0], [$r('app.color.FAFAFA'), 1.0]]
|
||||
} : {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('sys.color.ohos_id_color_foreground_contrary'), 1],
|
||||
[$r('sys.color.ohos_id_color_foreground_contrary'), 1]]
|
||||
})
|
||||
.height(WidthPercent.WH_100_100)
|
||||
.borderRadius($r('app.float.radius_20'))
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.textAlign(TextAlign.Start);
|
||||
}
|
||||
.padding($r('app.float.distance_4'))
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.borderRadius($r('app.float.radius_24'))
|
||||
.onTouch((event?: TouchEvent) => {
|
||||
if (event !== undefined) {
|
||||
if (event.type === TouchType.Down) {
|
||||
this.isTouched = true;
|
||||
}
|
||||
if (event.type === TouchType.Up) {
|
||||
this.isTouched = false;
|
||||
}
|
||||
}
|
||||
})
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'))
|
||||
.onClick(() => {
|
||||
this.deleteWarnDialog.open();
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@Component
|
||||
export struct CertInstallComponent {
|
||||
@State isTouched: boolean = false;
|
||||
@Link mFaPresenter: CmFaPresenter;
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
Row() {
|
||||
Text($r('app.string.installInStorageDevice'))
|
||||
.fontSize($r('app.float.font_16'))
|
||||
.lineHeight($r('app.float.wh_value_22'))
|
||||
.fontColor($r('app.color.font_color_182431'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({ left: $r('app.float.wh_value_8') });
|
||||
}
|
||||
|
||||
Image($r('app.media.ic_settings_arrow'))
|
||||
.width($r('app.float.wh_value_12'))
|
||||
.height($r('app.float.wh_value_24'))
|
||||
.fillColor($r('sys.color.ohos_id_color_primary'))
|
||||
.opacity($r('app.float.opacity_0_2'))
|
||||
.margin({ right: $r('app.float.wh_value_8') });
|
||||
}
|
||||
.borderRadius($r('app.float.radius_20'))
|
||||
.height(WidthPercent.WH_100_100)
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.linearGradient(this.isTouched ? {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('app.color.DCEAF9'), 0.0], [$r('app.color.FAFAFA'), 1.0]]
|
||||
} : {
|
||||
angle: 90,
|
||||
direction: GradientDirection.Right,
|
||||
colors: [[$r('sys.color.ohos_id_color_foreground_contrary'), 1],
|
||||
[$r('sys.color.ohos_id_color_foreground_contrary'), 1]]
|
||||
})
|
||||
.onTouch((event?: TouchEvent) => {
|
||||
if (event !== undefined) {
|
||||
if (event.type === TouchType.Down) {
|
||||
this.isTouched = true;
|
||||
}
|
||||
if (event.type === TouchType.Up) {
|
||||
this.isTouched = false;
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'))
|
||||
.padding($r('app.float.distance_4'))
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.borderRadius($r('app.float.radius_24'))
|
||||
.onClick(() => {
|
||||
this.mFaPresenter.startInstall()
|
||||
});
|
||||
}
|
||||
}
|
119
application/src/main/ets/pages/certPwdInput.ets
Normal file
@ -0,0 +1,119 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import HeadComponent from '../common/component/headComponent';
|
||||
import { WidthPercent, LocationChoice, ConfigValue } from '../common/util/ConfigData';
|
||||
import router from '@ohos.router';
|
||||
import CmFaPresenter from '../presenter/CmFaPresenter';
|
||||
import { GlobalContext } from '../common/GlobalContext';
|
||||
|
||||
@Entry
|
||||
@Component
|
||||
struct CertPwdInput {
|
||||
certPwd: string = '';
|
||||
@State mFaPresenter: CmFaPresenter = CmFaPresenter.getInstance();
|
||||
|
||||
onPageShow() {
|
||||
let uri = GlobalContext.getContext().getAbilityWant().uri;
|
||||
GlobalContext.getContext().clearAbilityWantUri();
|
||||
|
||||
if (uri === 'certInstall') {
|
||||
this.mFaPresenter.startInstall();
|
||||
} else if (uri === 'requestAuthorize') {
|
||||
this.mFaPresenter.startRequestAuth(GlobalContext.getContext().getAbilityWant().parameters?.appUid as string);
|
||||
}
|
||||
}
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
Column() {
|
||||
HeadComponent({ headName: $r('app.string.certificatePwdTab') });
|
||||
Text($r('app.string.certificatePwdInfo'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({
|
||||
top: $r('app.float.distance_24'),
|
||||
left: $r('app.float.distance_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start);
|
||||
|
||||
TextInput()
|
||||
.type(InputType.Password)
|
||||
.onChange((value: string) => {
|
||||
this.certPwd = value;
|
||||
})
|
||||
.maxLength(ConfigValue.PWD_MAX_LENGTH)
|
||||
.margin({
|
||||
top: $r('app.float.distance_16'),
|
||||
left: $r('app.float.distance_24'),
|
||||
right: $r('app.float.distance_24')
|
||||
})
|
||||
.height('40vp')
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_75_100);
|
||||
|
||||
Column() {
|
||||
Row() {
|
||||
Button() {
|
||||
Text($r('app.string.installPwdInputCancel'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('sys.color.ohos_id_color_text_hyperlink'))
|
||||
}
|
||||
.type(ButtonType.Capsule)
|
||||
.backgroundColor($r('app.color.install_cancel_bt_bg_color'))
|
||||
.width($r('app.float.component_button_width_phone'))
|
||||
.height($r('app.float.application_button_height'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_24'),
|
||||
})
|
||||
.onClick(() => {
|
||||
router.back();
|
||||
})
|
||||
|
||||
Button() {
|
||||
Text($r('app.string.installPwdInputConfirm'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.fontColor($r('app.color.install_confirm_bt_font_color'))
|
||||
}
|
||||
.type(ButtonType.Capsule)
|
||||
.backgroundColor($r('app.color.install_confirm_bt_bg_color'))
|
||||
.width($r('app.float.component_button_width_phone'))
|
||||
.height($r('app.float.application_button_height'))
|
||||
.margin({
|
||||
left: $r('app.float.distance_16'),
|
||||
right: $r('app.float.distance_24'),
|
||||
})
|
||||
.onClick(() => {
|
||||
GlobalContext.getContext().getPwdStore().setCertPwd(this.certPwd)
|
||||
router.pushUrl({
|
||||
url: 'pages/certInstallAliasInput',
|
||||
params: router.getParams()
|
||||
})
|
||||
})
|
||||
}
|
||||
.margin({ bottom: $r('app.float.wh_value_24') })
|
||||
}
|
||||
.justifyContent(FlexAlign.End)
|
||||
.height(WidthPercent.WH_25_100);
|
||||
}
|
||||
.backgroundColor($r('sys.color.ohos_id_color_sub_background'))
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.height(WidthPercent.WH_100_100);
|
||||
}
|
||||
}
|
306
application/src/main/ets/pages/requestAuth.ets
Normal file
@ -0,0 +1,306 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import CmAppCredAuthPresenter from '../presenter/CmAppCredAuthPresenter';
|
||||
import router from '@ohos.router';
|
||||
import { WidthPercent, LocationChoice, ConfigValue } from '../common/util/ConfigData';
|
||||
import { CredentialAbstractVo } from '../model/CertManagerVo/CredentialAbstractVo';
|
||||
import { RouterAppUidVo } from '../model/CertManagerVo/RouterInfoVo';
|
||||
|
||||
@CustomDialog
|
||||
@Component
|
||||
struct CustomDialogAuthForApp {
|
||||
controller?: CustomDialogController
|
||||
@State mAppCredAuthPresenter: CmAppCredAuthPresenter = CmAppCredAuthPresenter.getInstance();
|
||||
selectUri: string = '';
|
||||
private authScroller: Scroller = new Scroller();
|
||||
|
||||
aboutToAppear(): void {
|
||||
console.info('certPwdInput about to appear');
|
||||
let appUidInfo: RouterAppUidVo = router.getParams() as RouterAppUidVo;
|
||||
this.mAppCredAuthPresenter.updateAppNameFromUid(appUidInfo.appUid as string);
|
||||
this.mAppCredAuthPresenter.updateAppCredList();
|
||||
}
|
||||
|
||||
build() {
|
||||
Column() {
|
||||
GridContainer({
|
||||
columns: 12,
|
||||
sizeType: SizeType.Auto,
|
||||
gutter: vp2px(1) === 2 ? '12vp' : '0vp',
|
||||
margin: vp2px(1) === 2 ? '24vp' : '0vp'
|
||||
}) {
|
||||
Row({}) {
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 0 }, sm: { span: 0, offset: 0 },
|
||||
md: { span: 0, offset: 0 }, lg: { span: 2, offset: 0 }
|
||||
});
|
||||
|
||||
Column() {
|
||||
Text($r('app.string.pickCredToAuth'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_dialog_tittle'))
|
||||
.height($r('app.float.wh_value_56'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.margin({
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
|
||||
Text($r('app.string.requestAuthMsg', this.mAppCredAuthPresenter.appName))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_body1'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_primary'))
|
||||
.fontWeight(FontWeight.Regular)
|
||||
.margin({
|
||||
top: $r('app.float.wh_value_8'),
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
.alignSelf(ItemAlign.Start)
|
||||
|
||||
if (this.mAppCredAuthPresenter.credList.length > ConfigValue.REQUEST_AUTH_MAX_LENGTH) {
|
||||
Stack({ alignContent: Alignment.End }) {
|
||||
Scroll(this.authScroller) {
|
||||
List() {
|
||||
ForEach(this.mAppCredAuthPresenter.credList, (item: CredentialAbstractVo) => {
|
||||
ListItem() {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
|
||||
Column() {
|
||||
Text(item.alias)
|
||||
.fontSize($r('app.float.font_18'))
|
||||
.fontColor($r('app.color.request_auth_font_color'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.textAlign(TextAlign.Start);
|
||||
}
|
||||
.alignItems(HorizontalAlign.Start)
|
||||
|
||||
Column() {
|
||||
Radio({ value: item.alias, group: 'appCredGroup' })
|
||||
.checked(false)
|
||||
.onChange((value: boolean) => {
|
||||
console.log(item.alias + ' status is ' + value)
|
||||
if (value) {
|
||||
this.selectUri = item.keyUri;
|
||||
console.log('selectUri is ' + this.selectUri)
|
||||
}
|
||||
})
|
||||
}
|
||||
.alignItems(HorizontalAlign.End)
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
}
|
||||
.height($r('app.float.wh_value_64'))
|
||||
}, (item: CredentialAbstractVo) => JSON.stringify(item))
|
||||
}
|
||||
.scrollBar(BarState.Off)
|
||||
.divider({
|
||||
strokeWidth: $r('app.float.request_auth_strokeWidth'),
|
||||
color: $r('app.color.request_auth_color'),
|
||||
endMargin: $r('app.float.request_auth_divider_endMargin') })
|
||||
.backgroundColor($r('app.color.request_auth_background_color'))
|
||||
.visibility(this.mAppCredAuthPresenter.credList.length > 0 ? Visibility.Visible : Visibility.None)
|
||||
}
|
||||
.scrollBar(BarState.Off)
|
||||
.margin({
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
|
||||
ScrollBar({ scroller: this.authScroller, direction: ScrollBarDirection.Vertical,
|
||||
state: BarState.Auto }) {
|
||||
Text()
|
||||
.width($r('app.float.wh_value_3'))
|
||||
.height($r('app.float.wh_value_50'))
|
||||
.borderRadius($r('app.float.wh_value_10'))
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground'))
|
||||
.opacity(0.4)
|
||||
}
|
||||
.width($r('app.float.wh_value_3'))
|
||||
.margin({
|
||||
right: $r('app.float.wh_value_3')
|
||||
})
|
||||
}
|
||||
.height(WidthPercent.WH_50_100)
|
||||
} else {
|
||||
List() {
|
||||
ForEach(this.mAppCredAuthPresenter.credList, (item: CredentialAbstractVo) => {
|
||||
ListItem() {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
Column() {
|
||||
Text(item.alias)
|
||||
.fontSize($r('app.float.font_18'))
|
||||
.fontColor($r('app.color.request_auth_font_color'))
|
||||
.fontWeight(FontWeight.Medium)
|
||||
.textAlign(TextAlign.Start);
|
||||
}
|
||||
.alignItems(HorizontalAlign.Start)
|
||||
|
||||
Column() {
|
||||
Radio({ value: item.alias, group: 'appCredGroup' })
|
||||
.checked(false)
|
||||
.onChange((value: boolean) => {
|
||||
console.log(item.alias + ' status is ' + value)
|
||||
if (value) {
|
||||
this.selectUri = item.keyUri;
|
||||
console.log('selectUri is ' + this.selectUri)
|
||||
}
|
||||
})
|
||||
}
|
||||
.alignItems(HorizontalAlign.End)
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
}
|
||||
.height($r('app.float.wh_value_64'))
|
||||
}, (item: CredentialAbstractVo) => JSON.stringify(item))
|
||||
ListItem() {
|
||||
Flex({ justifyContent: FlexAlign.SpaceBetween, alignItems: ItemAlign.Center }) {
|
||||
Column() {
|
||||
Text()
|
||||
}
|
||||
.alignItems(HorizontalAlign.Start)
|
||||
|
||||
Column() {
|
||||
Radio({ value: 'null', group: 'appCredGroup' })
|
||||
.checked(false)
|
||||
.onChange((value: boolean) => {
|
||||
if (value) {
|
||||
this.selectUri = 'null';
|
||||
console.log('selectUri is ' + this.selectUri)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
.visibility(Visibility.None)
|
||||
}
|
||||
}
|
||||
.margin({
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
.scrollBar(BarState.Off)
|
||||
.divider({
|
||||
strokeWidth: $r('app.float.request_auth_strokeWidth'),
|
||||
color: $r('app.color.request_auth_color'),
|
||||
endMargin: $r('app.float.request_auth_divider_endMargin') })
|
||||
.backgroundColor($r('app.color.request_auth_background_color'))
|
||||
.visibility(this.mAppCredAuthPresenter.credList.length > 0 ? Visibility.Visible : Visibility.None)
|
||||
}
|
||||
|
||||
Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center,
|
||||
justifyContent: FlexAlign.SpaceAround }) {
|
||||
Button($r('app.string.requestAuthCancel'))
|
||||
.onClick(() => {
|
||||
this.mAppCredAuthPresenter.cancelProcess();
|
||||
if (this.controller !== undefined) {
|
||||
this.controller.close();
|
||||
}
|
||||
})
|
||||
.backgroundColor($r('app.color.request_auth_background_color'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_hyperlink'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_button1'))
|
||||
.width($r('app.float.wh_value_152'))
|
||||
.height($r('app.float.wh_value_40'))
|
||||
|
||||
Divider()
|
||||
.strokeWidth(ConfigValue.VERTICAL_DIVIDER_WIDTH)
|
||||
.color($r('sys.color.ohos_id_color_list_separator'))
|
||||
.vertical(true)
|
||||
.height($r('app.float.wh_value_40'))
|
||||
.opacity($r('app.float.opacity_0_2'))
|
||||
|
||||
Button($r('app.string.requestAuthFinish'))
|
||||
.onClick(() => {
|
||||
console.info('requestAuthorize uri: ' + this.selectUri);
|
||||
let appUidInfo: RouterAppUidVo = router.getParams() as RouterAppUidVo;
|
||||
if (appUidInfo !== undefined && appUidInfo.appUid != undefined) {
|
||||
console.info('requestAuthorize appUid: ' + appUidInfo.appUid);
|
||||
this.mAppCredAuthPresenter.requestAuthorize(this.selectUri, appUidInfo.appUid);
|
||||
if (this.controller !== undefined) {
|
||||
this.controller.close();
|
||||
}
|
||||
} else {
|
||||
console.info('requestAuthorize fail');
|
||||
}
|
||||
})
|
||||
.backgroundColor($r('app.color.request_auth_background_color'))
|
||||
.fontColor($r('sys.color.ohos_id_color_text_hyperlink'))
|
||||
.fontSize($r('sys.float.ohos_id_text_size_button1'))
|
||||
.width($r('app.float.wh_value_152'))
|
||||
.height($r('app.float.wh_value_40'))
|
||||
}
|
||||
.height($r('app.float.wh_value_64'))
|
||||
.padding({
|
||||
bottom: $r('app.float.wh_value_16')
|
||||
})
|
||||
.margin({
|
||||
left: $r('app.float.wh_value_24'),
|
||||
right: $r('app.float.wh_value_24')
|
||||
})
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.borderRadius($r('app.float.user_list_divider_borderRadius_value'))
|
||||
.backgroundColor($r('sys.color.ohos_id_color_foreground_contrary'))
|
||||
.useSizeType({
|
||||
xs: { span: 12, offset: 0 }, sm: { span: 12, offset: 0 },
|
||||
md: { span: 12, offset: 0 }, lg: { span: 8, offset: 2 }
|
||||
});
|
||||
|
||||
Column() {
|
||||
}
|
||||
.width(WidthPercent.WH_100_100)
|
||||
.useSizeType({
|
||||
xs: { span: 0, offset: 12 }, sm: { span: 0, offset: 12 },
|
||||
md: { span: 0, offset: 12 }, lg: { span: 2, offset: 10 }
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
.margin({
|
||||
bottom: $r('sys.float.ohos_id_dialog_margin_bottom'),
|
||||
left: $r('sys.float.ohos_id_dialog_margin_start'),
|
||||
right: $r('sys.float.ohos_id_dialog_margin_end'),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
@Entry
|
||||
@Component
|
||||
struct RadioAuth {
|
||||
dialogController: CustomDialogController = new CustomDialogController({
|
||||
builder: CustomDialogAuthForApp(),
|
||||
autoCancel: false,
|
||||
alignment: DialogAlignment.Bottom,
|
||||
customStyle: true,
|
||||
})
|
||||
|
||||
aboutToAppear() {
|
||||
console.info('RadioAuth aboutToAppear');
|
||||
let appUidInfo: RouterAppUidVo = router.getParams() as RouterAppUidVo;
|
||||
if (appUidInfo !== undefined && appUidInfo.appUid != undefined) {
|
||||
this.dialogController.open();
|
||||
} else {
|
||||
console.error('request auth appear failed');
|
||||
router.replaceUrl({ url: 'pages/certManagerFa' });
|
||||
}
|
||||
}
|
||||
|
||||
build() {
|
||||
}
|
||||
}
|
1148
application/src/main/ets/pages/trustedCa.ets
Normal file
123
application/src/main/ets/presenter/CmAppCredAuthPresenter.ets
Normal file
@ -0,0 +1,123 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import BundleModel from '../model/BundleModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { CredentialAbstractVo } from '../model/CertManagerVo/CredentialAbstractVo';
|
||||
import router from '@ohos.router';
|
||||
import { GlobalContext } from '../common/GlobalContext';
|
||||
import { AppInfoVo } from '../model/CertManagerVo/AppInfoVo';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
import Common from '@ohos.app.ability.common'
|
||||
|
||||
const TAG = 'CMAppCredAuthPresenter Presenter: ';
|
||||
const SUCCESS = 0;
|
||||
const FAIL = -1;
|
||||
|
||||
export default class CmAppCredAuthPresenter {
|
||||
private static sInstance: CmAppCredAuthPresenter;
|
||||
public credList: CredentialAbstractVo[] = [];
|
||||
public appName: string = '';
|
||||
|
||||
public static getInstance(): CmAppCredAuthPresenter {
|
||||
if (CmAppCredAuthPresenter.sInstance == null) {
|
||||
CmAppCredAuthPresenter.sInstance = new CmAppCredAuthPresenter();
|
||||
}
|
||||
return CmAppCredAuthPresenter.sInstance;
|
||||
}
|
||||
|
||||
onAboutToAppear(): void {
|
||||
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.credList = [];
|
||||
}
|
||||
|
||||
updateAppNameFromUid(uid: string): void {
|
||||
try {
|
||||
console.log('getAppNameFromUid start uid = ' + uid);
|
||||
BundleModel.getAppInfoList(Number(uid), (errCode: CMModelErrorCode, appInfo: AppInfoVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.appName = appInfo.appName;
|
||||
console.log('getAppNameFromUid success, appName = ' + this.appName);
|
||||
} else {
|
||||
console.error('getAppNameFromUid fail, uid = ' + uid);
|
||||
}
|
||||
});
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error('updateAppNameFromUid failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
}
|
||||
}
|
||||
|
||||
updateAppCredList(): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_APP_CRED,
|
||||
(errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.credList = credList;
|
||||
console.log('updateSystemTrustedCertificateList success, list: ' + JSON.stringify(credList));
|
||||
} else {
|
||||
console.error('updateSystemTrustedCertificateList failed');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
requestAuthorize(uri: string, appUid: string): void {
|
||||
console.log(TAG + 'requestAuthorize start uri :' + uri + 'appUid: ' + appUid);
|
||||
let want = GlobalContext.getContext().getAbilityWant();
|
||||
|
||||
certManagerModel.setAppAuth(CMModelOptType.CM_MODEL_OPT_APP_CRED, uri, appUid,
|
||||
true, (errCode: CMModelErrorCode, data: string) => {
|
||||
router.clear();
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.log('requestAuthorize success data: ' + data);
|
||||
if (want.parameters != undefined) {
|
||||
want.parameters.authUri = data;
|
||||
let ret1: Common.AbilityResult = {
|
||||
resultCode: SUCCESS,
|
||||
want: want
|
||||
};
|
||||
GlobalContext.getContext().getCmContext().terminateSelfWithResult(ret1);
|
||||
} else {
|
||||
let ret2: Common.AbilityResult = {
|
||||
resultCode: FAIL,
|
||||
want: want
|
||||
};
|
||||
console.error(TAG + 'requestAuthorize failed, undefined');
|
||||
GlobalContext.getContext().getCmContext().terminateSelfWithResult(ret2);
|
||||
}
|
||||
} else {
|
||||
console.error('requestAuthorize fail');
|
||||
let ret3: Common.AbilityResult = {
|
||||
resultCode: FAIL,
|
||||
want: want
|
||||
};
|
||||
GlobalContext.getContext().getCmContext().terminateSelfWithResult(ret3);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
cancelProcess(): void {
|
||||
console.log('cancelProcess start');
|
||||
router.clear();
|
||||
let ret: Common.AbilityResult = {
|
||||
resultCode: FAIL,
|
||||
want: GlobalContext.getContext().getAbilityWant()
|
||||
};
|
||||
GlobalContext.getContext().getCmContext().terminateSelfWithResult(ret);
|
||||
}
|
||||
}
|
111
application/src/main/ets/presenter/CmFaPresenter.ets
Normal file
@ -0,0 +1,111 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import picker from '@ohos.file.picker';
|
||||
import router from '@ohos.router';
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import FileIoModel from '../model/FileIoModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
import { RouterFileVo, RouterAppUidVo } from '../model/CertManagerVo/RouterInfoVo';
|
||||
|
||||
const TAG = 'CMFaPresenter: ';
|
||||
const PAGE_URI_PWD_INPUT = 'pages/certPwdInput';
|
||||
const PAGE_URI_ALIAS_INPUT = 'pages/certInstallAliasInput';
|
||||
|
||||
export default class CmFaPresenter {
|
||||
private static sInstance: CmFaPresenter;
|
||||
|
||||
public static getInstance(): CmFaPresenter {
|
||||
if (CmFaPresenter.sInstance == null) {
|
||||
CmFaPresenter.sInstance = new CmFaPresenter();
|
||||
}
|
||||
return CmFaPresenter.sInstance;
|
||||
}
|
||||
|
||||
onAboutToAppear(): void {
|
||||
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
}
|
||||
|
||||
routeToNext(fileUri: string): void {
|
||||
console.info(TAG + 'routeToNext fileUri: ' + fileUri);
|
||||
FileIoModel.getMediaFileSuffix(fileUri, (suffix: string | undefined) => {
|
||||
console.info(TAG + 'suffix ' + suffix);
|
||||
if (suffix !== undefined) {
|
||||
let fileInfo = new RouterFileVo(fileUri, suffix);
|
||||
if ((suffix === 'cer') || (suffix === 'pem')) {
|
||||
router.pushUrl({
|
||||
url: PAGE_URI_ALIAS_INPUT,
|
||||
params: fileInfo
|
||||
});
|
||||
} else {
|
||||
router.pushUrl({
|
||||
url: PAGE_URI_PWD_INPUT,
|
||||
params: fileInfo
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
startInstall(): void {
|
||||
try {
|
||||
let documentSelectOptions = new picker.DocumentSelectOptions();
|
||||
let documentPicker = new picker.DocumentViewPicker();
|
||||
console.info(TAG + 'start documentPicker.select');
|
||||
documentPicker.select(documentSelectOptions).then((documentSelectResult) => {
|
||||
if (documentSelectResult.length >= 1) {
|
||||
this.routeToNext(String(documentSelectResult[0]));
|
||||
} else {
|
||||
console.error(TAG + 'documentPicker.select length invalid:' + documentSelectResult.length);
|
||||
}
|
||||
}).catch((err: BusinessError) => {
|
||||
console.error(TAG + 'documentPicker.select failed with err, message: ' + err.message + ', code: ' + err.code);
|
||||
});
|
||||
} catch (err) {
|
||||
let e: BusinessError = err as BusinessError;
|
||||
console.error(TAG + 'DocumentViewPicker failed with err, message: ' + e.message + ', code: ' + e.code);
|
||||
}
|
||||
}
|
||||
|
||||
startRequestAuth(uri: string): void {
|
||||
let appUidInfo = new RouterAppUidVo(uri);
|
||||
router.replaceUrl({
|
||||
url: 'pages/requestAuth',
|
||||
params: appUidInfo
|
||||
});
|
||||
}
|
||||
|
||||
uninstallAllCert(): void {
|
||||
certManagerModel.delAllCertOrCred(CMModelOptType.CM_MODEL_OPT_USER_CA, (errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.log(TAG + 'uninstallAllCert CM_MODEL_OPT_USER_CA success');
|
||||
} else {
|
||||
console.error(TAG + 'uninstallAllCert CM_MODEL_OPT_USER_CA failed');
|
||||
}
|
||||
});
|
||||
|
||||
certManagerModel.delAllCertOrCred(CMModelOptType.CM_MODEL_OPT_APP_CRED, (errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.log(TAG + 'uninstallAllCert CM_MODEL_OPT_APP_CRED success');
|
||||
} else {
|
||||
console.error(TAG + 'uninstallAllCert CM_MODEL_OPT_APP_CRED failed');
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
76
application/src/main/ets/presenter/CmInstallPresenter.ets
Normal file
@ -0,0 +1,76 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import FileIoModel from '../model/FileIoModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import router from '@ohos.router';
|
||||
import { GlobalContext } from '../common/GlobalContext';
|
||||
|
||||
const TAG = 'CMInstallPresenter: ';
|
||||
|
||||
export default class CmInstallPresenter {
|
||||
private static sInstance: CmInstallPresenter;
|
||||
private optType: CMModelOptType = CMModelOptType.CM_MODEL_OPT_UNKNOWN;
|
||||
|
||||
public static getInstance(): CmInstallPresenter {
|
||||
if (CmInstallPresenter.sInstance == null) {
|
||||
CmInstallPresenter.sInstance = new CmInstallPresenter();
|
||||
}
|
||||
return CmInstallPresenter.sInstance;
|
||||
}
|
||||
|
||||
onAboutToAppear(): void {
|
||||
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.optType = CMModelOptType.CM_MODEL_OPT_UNKNOWN;
|
||||
}
|
||||
|
||||
updateCertFileType(suffix: string): void {
|
||||
console.info(TAG + 'updateCertFileType suffix: ' + suffix);
|
||||
if ((suffix === 'cer') || (suffix === 'pem')) {
|
||||
this.optType = CMModelOptType.CM_MODEL_OPT_USER_CA;
|
||||
} else if ((suffix === 'p12') || (suffix === 'jks') || (suffix === 'pfx')) {
|
||||
this.optType = CMModelOptType.CM_MODEL_OPT_APP_CRED;
|
||||
}
|
||||
}
|
||||
|
||||
getFileDataFromUri(uri: string, callback: Function): void {
|
||||
FileIoModel.getMediaFileData(uri, (data: Uint8Array) => {
|
||||
callback(data);
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
installCert(uri: string, alias: string, suffix: string): void {
|
||||
this.updateCertFileType(suffix);
|
||||
this.getFileDataFromUri(uri, (data: Uint8Array) => {
|
||||
certManagerModel.installCertOrCred(this.optType, alias, data,
|
||||
GlobalContext.getContext().getPwdStore().getCertPwd(), (errCode: CMModelErrorCode) => {
|
||||
console.info(TAG + 'installCertOrCred result: ' + JSON.stringify(errCode));
|
||||
GlobalContext.getContext().getPwdStore().clearCertPwd();
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.info(TAG + 'installCert success');
|
||||
} else {
|
||||
console.error(TAG + 'installCert failed');
|
||||
}
|
||||
router.clear();
|
||||
router.replaceUrl({ url: 'pages/certManagerFa' });
|
||||
});
|
||||
});
|
||||
}
|
||||
}
|
148
application/src/main/ets/presenter/CmShowAppCredPresenter.ets
Normal file
@ -0,0 +1,148 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import bundleModel from '../model/BundleModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { CredentialAbstractVo } from '../model/CertManagerVo/CredentialAbstractVo';
|
||||
import { CredentialVo } from '../model/CertManagerVo/CredentialVo';
|
||||
import { AppAuthorVo } from '../model/CertManagerVo/AppAuthorVo';
|
||||
import { AppInfoVo } from '../model/CertManagerVo/AppInfoVo';
|
||||
import { BusinessError } from '@ohos.base';
|
||||
|
||||
export default class CmShowAppCredPresenter {
|
||||
private static sInstance: CmShowAppCredPresenter;
|
||||
public credList: CredentialAbstractVo[] = [];
|
||||
public appInfoList: AppAuthorVo[] = [];
|
||||
public credInfo: CredentialVo = new CredentialVo('', '', '', 0, 0, new Uint8Array());
|
||||
|
||||
public static getInstance(): CmShowAppCredPresenter {
|
||||
if (CmShowAppCredPresenter.sInstance == null) {
|
||||
CmShowAppCredPresenter.sInstance = new CmShowAppCredPresenter();
|
||||
}
|
||||
return CmShowAppCredPresenter.sInstance;
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.credList = [];
|
||||
this.credInfo = new CredentialVo('', '', '', 0, 0, new Uint8Array());
|
||||
this.appInfoList = [];
|
||||
}
|
||||
|
||||
updateAppCredListCallback(callback: Function): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_APP_CRED,
|
||||
(errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
credList.sort((certAbs, certAbsOther): number => {
|
||||
let certAlias = certAbs.alias;
|
||||
let certAliasOther = certAbsOther.alias;
|
||||
if (certAlias <= certAliasOther) {
|
||||
return -1;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
});
|
||||
this.credList = credList;
|
||||
callback();
|
||||
} else {
|
||||
console.error('updateAppCredList error :' + JSON.stringify(errCode));
|
||||
this.credList = [];
|
||||
callback();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
updateAppCredList(): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_APP_CRED,
|
||||
(errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
credList.sort((certAbs, certAbsOther): number => {
|
||||
let certAlias = certAbs.alias;
|
||||
let certAliasOther = certAbsOther.alias;
|
||||
if (certAlias <= certAliasOther) {
|
||||
return -1;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
});
|
||||
this.credList = credList;
|
||||
} else {
|
||||
console.error('updateAppCredList error :' + JSON.stringify(errCode));
|
||||
this.credList = [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getAppCred(uri: string, callback: Function): void {
|
||||
certManagerModel.getCertOrCred(CMModelOptType.CM_MODEL_OPT_APP_CRED, uri,
|
||||
(errCode: CMModelErrorCode, credInfo: CredentialVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.credInfo = credInfo;
|
||||
} else {
|
||||
console.error('getAppCred error :' + JSON.stringify(errCode));
|
||||
this.credInfo.clearCredentialVo();
|
||||
}
|
||||
callback();
|
||||
});
|
||||
}
|
||||
|
||||
deleteAppCred(uri: string): void {
|
||||
certManagerModel.deleteCertOrCred(CMModelOptType.CM_MODEL_OPT_APP_CRED, uri, (errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.updateAppCredList();
|
||||
} else {
|
||||
console.error('deleteAppCred error :' + JSON.stringify(errCode));
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getAuthorizedAppList(uri: string): void {
|
||||
this.appInfoList = [];
|
||||
certManagerModel.getAuthAppList(CMModelOptType.CM_MODEL_OPT_APP_CRED, uri,
|
||||
(errCode: CMModelErrorCode, appUidList: Array<string>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
for (let i = 0; i < appUidList.length; i++) {
|
||||
bundleModel.getAppInfoList(Number(appUidList[i]), (errCode: CMModelErrorCode, appInfo: AppInfoVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.appInfoList.push(
|
||||
new AppAuthorVo(String(appInfo.appImage), String(appUidList[i]), String(appInfo.appName), true));
|
||||
console.log('appInfoList: ' + JSON.stringify(this.appInfoList));
|
||||
}
|
||||
});
|
||||
}
|
||||
} else {
|
||||
console.error('getAuthorizedAppList error :' + JSON.stringify(errCode));
|
||||
this.appInfoList = [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
async removeGrantedAppList(uri: string): Promise<void> {
|
||||
console.log('enter removeGrantedAppList');
|
||||
for (let i = 0; i < this.appInfoList.length; i++) {
|
||||
if (!this.appInfoList[i].status) {
|
||||
try {
|
||||
let res = await certManagerModel.setAppAuthPromise(CMModelOptType.CM_MODEL_OPT_APP_CRED, uri,
|
||||
this.appInfoList[i].uid, false);
|
||||
console.log('removeGrantedAppList succeed' + JSON.stringify(res));
|
||||
} catch (error) {
|
||||
let e: BusinessError = error as BusinessError;
|
||||
console.error('removeGrantedAppList error, message: ' + e.message + ', code: ' + e.code);
|
||||
}
|
||||
}
|
||||
}
|
||||
console.log('leave removeGrantedAppList');
|
||||
}
|
||||
}
|
@ -0,0 +1,71 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { CredentialAbstractVo } from '../model/CertManagerVo/CredentialAbstractVo';
|
||||
import { CredentialVo } from '../model/CertManagerVo/CredentialVo';
|
||||
|
||||
export default class CmShowPrivateCredPresenter {
|
||||
private static sInstance: CmShowPrivateCredPresenter;
|
||||
public credList: CredentialAbstractVo[] = [];
|
||||
public credInfo: CredentialVo = new CredentialVo('', '', '', 0, 0, new Uint8Array());
|
||||
|
||||
public static getInstance(): CmShowPrivateCredPresenter {
|
||||
if (CmShowPrivateCredPresenter.sInstance == null) {
|
||||
CmShowPrivateCredPresenter.sInstance = new CmShowPrivateCredPresenter();
|
||||
}
|
||||
return CmShowPrivateCredPresenter.sInstance;
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.credList = [];
|
||||
this.credInfo = new CredentialVo('', '', '', 0, 0, new Uint8Array());
|
||||
}
|
||||
|
||||
updatePrivateCredList(): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED,
|
||||
(errCode: CMModelErrorCode, credList: Array<CredentialAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
credList.sort((certAbs, certAbsOther) => {
|
||||
let certAlias = certAbs.alias;
|
||||
let certAliasOther = certAbsOther.alias;
|
||||
if (certAlias <= certAliasOther) {
|
||||
return -1;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
});
|
||||
this.credList = credList;
|
||||
} else {
|
||||
console.error('updatePrivateCredList error :' + JSON.stringify(errCode));
|
||||
this.credList = [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getPrivateCred(uri: string, callback: Function): void {
|
||||
certManagerModel.getCertOrCred(CMModelOptType.CM_MODEL_OPT_PRIVATE_CRED, uri,
|
||||
(errCode: CMModelErrorCode, credInfo: CredentialVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.credInfo = credInfo;
|
||||
} else {
|
||||
console.error('getPrivateCred error :' + JSON.stringify(errCode));
|
||||
this.credInfo.clearCredentialVo();
|
||||
}
|
||||
callback();
|
||||
});
|
||||
}
|
||||
}
|
95
application/src/main/ets/presenter/CmShowSysCaPresenter.ets
Normal file
@ -0,0 +1,95 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { CertAbstractVo } from '../model/CertManagerVo/CertAbstractVo';
|
||||
import { CertInfoVo } from '../model/CertManagerVo/CertInfoVo';
|
||||
|
||||
const TAG = 'CMShowSysCa Presenter: ';
|
||||
|
||||
export default class CmShowSysCaPresenter {
|
||||
private static sInstance: CmShowSysCaPresenter;
|
||||
public certList: CertAbstractVo[] = [];
|
||||
public certInfo: CertInfoVo = new CertInfoVo('', '', false, '', '', '', '', '', '',
|
||||
new Uint8Array(), new Map(), new Map(), new Map());
|
||||
|
||||
public static getInstance(): CmShowSysCaPresenter {
|
||||
if (CmShowSysCaPresenter.sInstance == null) {
|
||||
CmShowSysCaPresenter.sInstance = new CmShowSysCaPresenter();
|
||||
}
|
||||
return CmShowSysCaPresenter.sInstance;
|
||||
}
|
||||
|
||||
onAboutToAppear(): void {
|
||||
this.updateSystemTrustedCertificateList();
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.certList = [];
|
||||
this.certInfo = new CertInfoVo('', '', false, '', '', '', '', '', '',
|
||||
new Uint8Array(), new Map(), new Map(), new Map());
|
||||
}
|
||||
|
||||
updateSystemTrustedCertificateList(): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_SYSTEM_CA,
|
||||
(errCode: CMModelErrorCode, certList: Array<CertAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
certList.sort((certAbs, certAbsOther): number => {
|
||||
let certAlias = certAbs.certAlias;
|
||||
let certAliasOther = certAbsOther.certAlias;
|
||||
if (certAlias <= certAliasOther) {
|
||||
return -1;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
});
|
||||
this.certList = certList;
|
||||
console.log('updateSystemTrustedCertificateList success, list: ' + JSON.stringify(certList));
|
||||
} else {
|
||||
console.error(TAG + 'updateSystemTrustedCertificateList fail,errCode is' + errCode);
|
||||
this.certList = [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getSystemTrustedCertificate(uri: string, callback: Function): void {
|
||||
certManagerModel.getCertOrCred(CMModelOptType.CM_MODEL_OPT_SYSTEM_CA, uri,
|
||||
(errCode: CMModelErrorCode, certInfo: CertInfoVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.info(TAG + 'getSystemTrustedCertificate success,errCode is ' + errCode + ' certInfo is' +
|
||||
JSON.stringify(certInfo));
|
||||
this.certInfo = certInfo;
|
||||
callback();
|
||||
} else {
|
||||
console.error(TAG + 'getSystemTrustedCertificate fail,errCode is' + errCode);
|
||||
this.certInfo.clearCertInfoVo();
|
||||
callback();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
setSystemCertificateStatus(uri: string, status: boolean): void {
|
||||
certManagerModel.setCertStatus(CMModelOptType.CM_MODEL_OPT_SYSTEM_CA, uri, status,
|
||||
(errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.info(TAG + 'setSystemCertificateStatus success,errCode is' + errCode);
|
||||
this.updateSystemTrustedCertificateList();
|
||||
} else {
|
||||
console.error(TAG + 'setSystemCertificateStatus fail,errCode is' + errCode);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
106
application/src/main/ets/presenter/CmShowUserCaPresenter.ets
Normal file
@ -0,0 +1,106 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2024 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
import certManagerModel from '../model/CertMangerModel';
|
||||
import { CMModelErrorCode, CMModelOptType } from '../model/CertMangerModel';
|
||||
import { CertAbstractVo } from '../model/CertManagerVo/CertAbstractVo';
|
||||
import { CertInfoVo } from '../model/CertManagerVo/CertInfoVo';
|
||||
|
||||
const TAG = 'CMFaShowUserCa Presenter: ';
|
||||
|
||||
export default class CmShowUserCaPresenter {
|
||||
private static sInstance: CmShowUserCaPresenter;
|
||||
public certList: CertAbstractVo[] = [];
|
||||
public certInfo: CertInfoVo = new CertInfoVo('', '', false, '', '', '', '', '', '',
|
||||
new Uint8Array(), new Map(), new Map(), new Map());
|
||||
|
||||
public static getInstance(): CmShowUserCaPresenter {
|
||||
if (CmShowUserCaPresenter.sInstance == null) {
|
||||
CmShowUserCaPresenter.sInstance = new CmShowUserCaPresenter();
|
||||
}
|
||||
return CmShowUserCaPresenter.sInstance;
|
||||
}
|
||||
|
||||
onAboutToAppear(): void {
|
||||
|
||||
}
|
||||
|
||||
aboutToDisappear(): void {
|
||||
this.certList = [];
|
||||
this.certInfo = new CertInfoVo('', '', false, '', '', '', '', '', '',
|
||||
new Uint8Array(), new Map(), new Map(), new Map());
|
||||
}
|
||||
|
||||
updateUserTrustedCertificateList(): void {
|
||||
certManagerModel.getCertOrCredList(CMModelOptType.CM_MODEL_OPT_USER_CA,
|
||||
(errCode: CMModelErrorCode, certList: Array<CertAbstractVo>) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
certList.sort((certAbs, certAbsOther): number => {
|
||||
let certAlias = certAbs.certAlias;
|
||||
let certAliasOther = certAbsOther.certAlias;
|
||||
if (certAlias <= certAliasOther) {
|
||||
return -1;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
});
|
||||
this.certList = certList;
|
||||
console.log('updateUserTrustedCertificateList success, list: ' + JSON.stringify(certList));
|
||||
} else {
|
||||
console.error(TAG + 'updateUserTrustedCertificateList fail,errCode is ' + errCode);
|
||||
this.certList = [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getUserTrustedCertificate(uri: string, callback: Function): void {
|
||||
certManagerModel.getCertOrCred(CMModelOptType.CM_MODEL_OPT_USER_CA, uri,
|
||||
(errCode: CMModelErrorCode, certInfo: CertInfoVo) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
console.info(TAG + 'getUserTrustedCertificate success, errCode is ' + errCode + ' certInfo is' +
|
||||
JSON.stringify(certInfo));
|
||||
this.certInfo = certInfo;
|
||||
callback();
|
||||
} else {
|
||||
console.error(TAG + 'getUserTrustedCertificate fail, errCode is ' + errCode);
|
||||
this.certInfo.clearCertInfoVo();
|
||||
callback();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
setUserCertificateStatus(uri: string, status: boolean): void {
|
||||
certManagerModel.setCertStatus(CMModelOptType.CM_MODEL_OPT_USER_CA, uri, status, (errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.getUserTrustedCertificate(uri, () => {
|
||||
console.info(TAG + 'setCerStatus then getUserTrustedCertificate,errCode is' + errCode);
|
||||
});
|
||||
} else {
|
||||
console.error(TAG + 'setUserCertificateStatus fail,errCode is ' + errCode);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
deleteUserCertificate(uri: string, callback: Function): void {
|
||||
certManagerModel.deleteCertOrCred(CMModelOptType.CM_MODEL_OPT_USER_CA, uri, (errCode: CMModelErrorCode) => {
|
||||
if (errCode === CMModelErrorCode.CM_MODEL_ERROR_SUCCESS) {
|
||||
this.updateUserTrustedCertificateList();
|
||||
} else {
|
||||
console.error(TAG + 'deleteUserCertificate fail,errCode is ' + errCode);
|
||||
}
|
||||
callback();
|
||||
});
|
||||
}
|
||||
}
|
77
application/src/main/module.json5
Normal file
@ -0,0 +1,77 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
{
|
||||
"module": {
|
||||
"name": "application",
|
||||
"type": "feature",
|
||||
"srcEntry": "./ets/Application/AbilityStage.ts",
|
||||
"description": "$string:mainability_description",
|
||||
"mainElement": "MainAbility",
|
||||
"deviceTypes": [
|
||||
"default"
|
||||
],
|
||||
"metadata": [
|
||||
{
|
||||
"name": "ArkTSPartialUpdate",
|
||||
"value": "true"
|
||||
},
|
||||
{
|
||||
"name": "partialUpdateStrictCheck",
|
||||
"value": "all"
|
||||
}
|
||||
],
|
||||
"deliveryWithInstall": true,
|
||||
"installationFree": false,
|
||||
"pages": "$profile:main_pages",
|
||||
"abilities": [
|
||||
{
|
||||
"name": "MainAbility",
|
||||
"srcEntrance": "./ets/MainAbility/MainAbility.ts",
|
||||
"description": "$string:mainability_description",
|
||||
"icon": "$media:icon",
|
||||
"label": "$string:entry_MainAbility",
|
||||
"visible": true,
|
||||
"launchType": "singleton",
|
||||
"startWindowIcon": "$media:icon",
|
||||
"startWindowBackground": "$color:color_333333_grey",
|
||||
"orientation": "auto_rotation_restricted",
|
||||
"skills": [
|
||||
{
|
||||
"entities": [
|
||||
"entity.system.home"
|
||||
],
|
||||
"actions": [
|
||||
"action.system.home"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
],
|
||||
"requestPermissions": [
|
||||
{
|
||||
"name": "ohos.permission.GET_BUNDLE_INFO"
|
||||
},
|
||||
{
|
||||
"name": "ohos.permission.ACCESS_CERT_MANAGER_INTERNAL"
|
||||
},
|
||||
{
|
||||
"name": "ohos.permission.ACCESS_CERT_MANAGER"
|
||||
},
|
||||
{
|
||||
"name": "ohos.permission.GET_BUNDLE_RESOURCES"
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
272
application/src/main/resources/base/element/color.json
Normal file
@ -0,0 +1,272 @@
|
||||
{
|
||||
"color": [
|
||||
{
|
||||
"name": "color_333333_grey",
|
||||
"value": "#333333"
|
||||
},
|
||||
{
|
||||
"name": "color_666666_grey",
|
||||
"value": "#666666"
|
||||
},
|
||||
{
|
||||
"name": "color_999999_grey",
|
||||
"value": "#999999"
|
||||
},
|
||||
{
|
||||
"name": "color_E3E3E3_grey",
|
||||
"value": "#E3E3E3"
|
||||
},
|
||||
{
|
||||
"name": "color_D8D8D8_grey",
|
||||
"value": "#D8D8D8"
|
||||
},
|
||||
{
|
||||
"name": "color_button_grey",
|
||||
"value": "#1824310D"
|
||||
},
|
||||
{
|
||||
"name": "color_00000000_transparent",
|
||||
"value": "#00000000"
|
||||
},
|
||||
{
|
||||
"name": "volume_bg_color",
|
||||
"value": "#CCFFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "white_bg_color",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "font_color_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "font_color_007DFF",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "search_no_result_text_color",
|
||||
"value": "$color:font_color_182431"
|
||||
},
|
||||
{
|
||||
"name": "search_result_text_color",
|
||||
"value": "$color:font_color_182431"
|
||||
},
|
||||
{
|
||||
"name": "search_result_text_color_highlight",
|
||||
"value": "$color:font_color_007DFF"
|
||||
},
|
||||
{
|
||||
"name": "bluetooth_text_color_highlight",
|
||||
"value": "$color:font_color_007DFF"
|
||||
},
|
||||
{
|
||||
"name": "FAFAFA",
|
||||
"value": "#FAFAFA"
|
||||
},
|
||||
{
|
||||
"name": "DCEAF9",
|
||||
"value": "#DCEAF9"
|
||||
},
|
||||
{
|
||||
"name": "4C89F0",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "D1D0DB",
|
||||
"value": "#D1D0DB"
|
||||
},
|
||||
{
|
||||
"name": "cm_del_all_font_color",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "cm_del_all_cancel_button_color",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "cm_del_all_delete_button_color",
|
||||
"value": "#FA2A2D"
|
||||
},
|
||||
{
|
||||
"name": "request_auth_font_color",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "request_auth_background_color",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "request_auth_bt_font_color",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "request_auth_color",
|
||||
"value": "#E5E5E5"
|
||||
},
|
||||
{
|
||||
"name": "install_cancel_bt_font_color",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "install_cancel_bt_bg_color",
|
||||
"value": "#0d182431"
|
||||
},
|
||||
{
|
||||
"name": "install_confirm_bt_font_color",
|
||||
"value": "#ffffffff"
|
||||
},
|
||||
{
|
||||
"name": "install_confirm_bt_bg_color",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "install_confirm_bt_bg_disable_color",
|
||||
"value": "#66007DFF"
|
||||
},
|
||||
{
|
||||
"name": "install_info_font_color",
|
||||
"value": "#E6000000"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_name_color",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_Toggle_selectColor",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_title_color",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_list_backgroundColor",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_finishColor",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "credentials_app_finish_backgroundColor",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "credentials_detail_keyNum_fontColor",
|
||||
"value": "#000000"
|
||||
},
|
||||
{
|
||||
"name": "credentials_detail_close_fontColor",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "warning_delete_fontColor",
|
||||
"value": "#FF0000"
|
||||
},
|
||||
{
|
||||
"name": "public_delete_fontColor",
|
||||
"value": "#CD5C5C"
|
||||
},
|
||||
{
|
||||
"name": "evidenceList_TabBuilder_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "Evidence_color",
|
||||
"value": "#0D000000"
|
||||
},
|
||||
{
|
||||
"name": "Evidence_backgroundColor",
|
||||
"value": "#F1F3F5"
|
||||
},
|
||||
{
|
||||
"name": "sys_list_divider_color_000000",
|
||||
"value": "#0D000000"
|
||||
},
|
||||
{
|
||||
"name": "TrustedEvidence_TabBuilder_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "sys_list_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "user_list_divider_color_000000",
|
||||
"value": "#0D000000"
|
||||
},
|
||||
{
|
||||
"name": "user_list_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "componentUser_text_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "ComponentSystem_text_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "ComponentSystem_Toggle_selectedColor_007DFF",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_text_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_list_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_fontColor_4C89F0",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_text_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_Toggle_selectedColor_007DFF",
|
||||
"value": "#007DFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_firButton_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_firButton_fontColor_4C89F0",
|
||||
"value": "#4C89F0"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_secButton_fontColor_FF0000",
|
||||
"value": "#FF0000"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_secButton_backgroundColor_FFFFFF",
|
||||
"value": "#FFFFFF"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_secButton_fontColor_FF0000",
|
||||
"value": "#FF0000"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_Text_fontColor_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "CertManager_Divider_Color_182431",
|
||||
"value": "#182431"
|
||||
},
|
||||
{
|
||||
"name": "TrustedEvidence_tabs_backgroundColor_F1F3F5",
|
||||
"value": "#F1F3F5"
|
||||
}
|
||||
]
|
||||
}
|
1680
application/src/main/resources/base/element/float.json
Normal file
286
application/src/main/resources/base/element/string.json
Normal file
@ -0,0 +1,286 @@
|
||||
{
|
||||
"string": [
|
||||
{
|
||||
"name": "entry_MainAbility",
|
||||
"value": "证书管理"
|
||||
},
|
||||
{
|
||||
"name": "mainability_description",
|
||||
"value": "ETS_Empty Feature Ability"
|
||||
},
|
||||
{
|
||||
"name": "version",
|
||||
"value": "版本 "
|
||||
},
|
||||
{
|
||||
"name": "certificateTab",
|
||||
"value": "证书与凭据"
|
||||
},
|
||||
{
|
||||
"name": "certificateManage",
|
||||
"value": "证书管理"
|
||||
},
|
||||
{
|
||||
"name": "trustedEvidence",
|
||||
"value": "受信任的证书"
|
||||
},
|
||||
{
|
||||
"name": "userEvidence",
|
||||
"value": "凭据列表"
|
||||
},
|
||||
{
|
||||
"name": "installInStorageDevice",
|
||||
"value": "从存储设备安装"
|
||||
},
|
||||
{
|
||||
"name": "installCertificateFailed",
|
||||
"value": "从存储设备安装失败"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdTab",
|
||||
"value": "提取证书"
|
||||
},
|
||||
{
|
||||
"name": "certificateAliasTab",
|
||||
"value": "设置证书"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdInfo",
|
||||
"value": "输入证书密码以提取"
|
||||
},
|
||||
{
|
||||
"name": "certificateAliasInfo",
|
||||
"value": "输入证书名称"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCred",
|
||||
"value": "删除所有证书与凭据"
|
||||
},
|
||||
|
||||
|
||||
{
|
||||
"name": "deleteAllCredDialogTitle",
|
||||
"value": "删除所有证书与凭据"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredDialogMessage",
|
||||
"value": "所有用户证书与凭据将被永久删除。是否删除?"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredCancel",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredDelete",
|
||||
"value": "删除"
|
||||
},
|
||||
{
|
||||
"name": "pickCredToAuth",
|
||||
"value": "选择证书授权"
|
||||
},
|
||||
{
|
||||
"name": "requestAuthMsg",
|
||||
"value": "应用\"%s\"请求使用证书。选择一个证书可让该应用对服务器使用此身份凭证。该应用已将请求服务标识为\"localhost\",您只应向信任的应用授予使用证书的权限。"
|
||||
},
|
||||
{
|
||||
"name": "requestAuthCancel",
|
||||
"value": "拒绝"
|
||||
},
|
||||
{
|
||||
"name": "requestAuthFinish",
|
||||
"value": "授权"
|
||||
},
|
||||
{
|
||||
"name": "requestFailPromptMsg",
|
||||
"value": "授权失败,无效AppUid"
|
||||
},
|
||||
{
|
||||
"name": "installPwdInputCancel",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "installPwdInputConfirm",
|
||||
"value": "提取"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputCancel",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputConfirm",
|
||||
"value": "确定"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputInfo",
|
||||
"value": "注:此证书颁发者可能会检查进出设备的所有流量\n该数据包包含:CA证书"
|
||||
},
|
||||
{
|
||||
"name": "managerAuthApp",
|
||||
"value": "管理授权应用"
|
||||
},
|
||||
{
|
||||
"name": "cancelAuthApp",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "finishAuthApp",
|
||||
"value": "完成"
|
||||
},
|
||||
{
|
||||
"name": "evidenceDetails",
|
||||
"value": "凭据详情"
|
||||
},
|
||||
{
|
||||
"name": "entryContains",
|
||||
"value": "此条目包含:"
|
||||
},
|
||||
{
|
||||
"name": "keyNum",
|
||||
"value": " %s个用户密钥"
|
||||
},
|
||||
{
|
||||
"name": "userCerNum",
|
||||
"value": " %s个用户证书"
|
||||
},
|
||||
{
|
||||
"name": "privateDetailsClose",
|
||||
"value": "关闭"
|
||||
},
|
||||
{
|
||||
"name": "publicDetailsCancel",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "publicDetailsDelete",
|
||||
"value": "删除"
|
||||
},
|
||||
{
|
||||
"name": "warning_title",
|
||||
"value": "删除凭据"
|
||||
},
|
||||
{
|
||||
"name": "warning_message",
|
||||
"value": "删除后,被授权此凭据的应用将无法正常使用。是否删除?"
|
||||
},
|
||||
{
|
||||
"name": "warning_cancel",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "warning_delete",
|
||||
"value": "删除"
|
||||
},
|
||||
{
|
||||
"name": "tabName_public",
|
||||
"value": "公共"
|
||||
},
|
||||
{
|
||||
"name": "tabName_private",
|
||||
"value": "私有"
|
||||
},
|
||||
{
|
||||
"name": "system",
|
||||
"value": "系统"
|
||||
},
|
||||
{
|
||||
"name": "user",
|
||||
"value": "用户"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_firText",
|
||||
"value": "证书详情"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_firListItem_text",
|
||||
"value": "颁发给:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_secListItem_text",
|
||||
"value": "颁发者:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_thdListItem_text",
|
||||
"value": "有效期:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_text",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_on",
|
||||
"value": "启用"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_off",
|
||||
"value": "禁用"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Status_true",
|
||||
"value": "已启用"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Status_false",
|
||||
"value": "已禁用"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_firButton_text",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_secButton_text",
|
||||
"value": "删除"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_text",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_title_text",
|
||||
"value": "删除证书"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_message_text",
|
||||
"value": "删除后,被授权此证书的应用将无法正常使用。是否删除?"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_firButton_text",
|
||||
"value": "取消"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_secButton_text",
|
||||
"value": "删除"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_firText",
|
||||
"value": "常用名称:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_secText",
|
||||
"value": "组织:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_thdText",
|
||||
"value": "组织单位:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_fouText",
|
||||
"value": "序列号:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_fifText",
|
||||
"value": "颁发时间:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_sixText",
|
||||
"value": "有效期至:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_fouListItem_text",
|
||||
"value": "指纹:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_FingerPrint_text",
|
||||
"value": "SHA-256 指纹:"
|
||||
}
|
||||
]
|
||||
}
|
13
application/src/main/resources/base/media/ic_back.svg
Normal file
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
<title>Public/ic_public_back</title>
|
||||
<defs>
|
||||
<path d="M5.31079777,13.7499686 L11.2803301,19.7196699 L11.3140714,19.7556673 C11.5727547,20.0502619 11.5615076,20.4991526 11.2803301,20.7803301 C10.9991526,21.0615076 10.5502619,21.0727547 10.2556673,20.8140714 L10.2196699,20.7803301 L3.18929777,13.7499686 L5.31079777,13.7499686 Z M11.2803301,3.21966991 C11.5615076,3.5008474 11.5727547,3.94973814 11.3140714,4.24433269 L11.2803301,4.28033009 L4.3105,11.25 L21,11.25 C21.3994202,11.25 21.7259152,11.56223 21.7487268,11.9559318 L21.75,12 C21.75,12.3994202 21.43777,12.7259152 21.0440682,12.7487268 L21,12.75 L3.10355339,12.75 C2.8383369,12.75 2.58398299,12.6446432 2.39644661,12.4571068 C2.01893979,12.0796 2.00635623,11.4753589 2.35869593,11.0827365 L2.39644661,11.0428932 L10.2196699,3.21966991 C10.5125631,2.9267767 10.9874369,2.9267767 11.2803301,3.21966991 Z" id="path-1"></path>
|
||||
</defs>
|
||||
<g id="Public/ic_public_back" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||
<mask id="mask-2" fill="white">
|
||||
<use xlink:href="#path-1"></use>
|
||||
</mask>
|
||||
<use id="形状结合" fill="#000000" fill-rule="nonzero" xlink:href="#path-1"></use>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 1.4 KiB |
3
application/src/main/resources/base/media/ic_close.svg
Normal file
@ -0,0 +1,3 @@
|
||||
<svg id="图层_1" data-name="图层 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 96 96"><defs>
|
||||
<style>.cls-1{fill:#1a1a1a;}</style>
|
||||
</defs><title>_ic</title><path class="cls-1" d="M76.29,72.05,52.24,48,76.29,24a3,3,0,1,0-4.24-4.24l-24,24-24-24A3,3,0,1,0,19.71,24L43.76,48l-24,24A3,3,0,1,0,24,76.29L48,52.24l24,24.05a3,3,0,0,0,4.24-4.24Z"/></svg>
|
After Width: | Height: | Size: 356 B |
13
application/src/main/resources/base/media/ic_delete.svg
Normal file
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
<title>xxxhdpi/ic_delete</title>
|
||||
<defs>
|
||||
<path d="M5.629,7.5 L6.72612901,18.4738834 C6.83893748,19.6019681 7.77211147,20.4662096 8.89848718,20.4990325 L8.96496269,20.5 L15.0342282,20.5 C16.1681898,20.5 17.1211231,19.6570911 17.2655686,18.5392856 L17.2731282,18.4732196 L18.1924161,9.2527383 L18.369,7.5 L19.877,7.5 L19.6849078,9.40262938 L18.7657282,18.6220326 C18.5772847,20.512127 17.0070268,21.9581787 15.1166184,21.9991088 L15.0342282,22 L8.96496269,22 C7.06591715,22 5.47142703,20.5815579 5.24265599,18.7050136 L5.23357322,18.6231389 L4.121,7.5 L5.629,7.5 Z M10.25,11.75 C10.6642136,11.75 11,12.0857864 11,12.5 L11,18.5 C11,18.9142136 10.6642136,19.25 10.25,19.25 C9.83578644,19.25 9.5,18.9142136 9.5,18.5 L9.5,12.5 C9.5,12.0857864 9.83578644,11.75 10.25,11.75 Z M13.75,11.75 C14.1642136,11.75 14.5,12.0857864 14.5,12.5 L14.5,18.5 C14.5,18.9142136 14.1642136,19.25 13.75,19.25 C13.3357864,19.25 13,18.9142136 13,18.5 L13,12.5 C13,12.0857864 13.3357864,11.75 13.75,11.75 Z M12,1.75 C13.7692836,1.75 15.2083571,3.16379796 15.2491124,4.92328595 L15.25,5 L21,5 C21.4142136,5 21.75,5.33578644 21.75,5.75 C21.75,6.14942022 21.43777,6.47591522 21.0440682,6.49872683 L21,6.5 L14.5,6.5 C14.1005798,6.5 13.7740848,6.18777001 13.7512732,5.7940682 L13.75,5.75 L13.75,5 C13.75,4.03350169 12.9664983,3.25 12,3.25 C11.0536371,3.25 10.2827253,4.00119585 10.2510148,4.93983756 L10.25,5 L10.25,5.75 C10.25,6.14942022 9.93777001,6.47591522 9.5440682,6.49872683 L9.5,6.5 L2.75,6.5 C2.33578644,6.5 2,6.16421356 2,5.75 C2,5.35057978 2.31222999,5.02408478 2.7059318,5.00127317 L2.75,5 L8.75,5 C8.75,3.20507456 10.2050746,1.75 12,1.75 Z" id="path-1"></path>
|
||||
</defs>
|
||||
<g id="ic_delete" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||
<mask id="mask-2" fill="white">
|
||||
<use xlink:href="#path-1"></use>
|
||||
</mask>
|
||||
<use id="形状结合" fill="#000000" fill-rule="nonzero" xlink:href="#path-1"></use>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 2.1 KiB |
1
application/src/main/resources/base/media/ic_move.svg
Normal file
@ -0,0 +1 @@
|
||||
<svg id="图层_1" data-name="图层 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 96 96"><defs><style>.cls-1{fill:#1a1a1a;}</style></defs><title>ic</title><path class="cls-1" d="M15,42H81a3,3,0,0,0,0-6H15a3,3,0,0,0,0,6Z"/><path class="cls-1" d="M81,54H15a3,3,0,0,0,0,6H81a3,3,0,0,0,0-6Z"/></svg>
|
After Width: | Height: | Size: 301 B |
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
<title>Public/ic_public_cancel</title>
|
||||
<defs>
|
||||
<path d="M19.7781746,4.22182541 C20.0710678,4.51471863 20.0710678,4.98959236 19.7781746,5.28248558 L5.28248558,19.7781746 C4.98959236,20.0710678 4.51471863,20.0710678 4.22182541,19.7781746 C3.92893219,19.4852814 3.92893219,19.0104076 4.22182541,18.7175144 L10.9395166,11.9994697 L4.22182541,5.28248558 C3.92893219,4.98959236 3.92893219,4.51471863 4.22182541,4.22182541 C4.51471863,3.92893219 4.98959236,3.92893219 5.28248558,4.22182541 L12,10.9389863 L18.7175144,4.22182541 C19.0104076,3.92893219 19.4852814,3.92893219 19.7781746,4.22182541 Z M19.7781746,18.7175144 C20.0710678,19.0104076 20.0710678,19.4852814 19.7781746,19.7781746 C19.4852814,20.0710678 19.0104076,20.0710678 18.7175144,19.7781746 L12.7072836,13.7675902 L13.767767,12.7071068 L19.7781746,18.7175144 Z" id="path-1"></path>
|
||||
</defs>
|
||||
<g id="Public/ic_public_cancel" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||
<mask id="mask-2" fill="white">
|
||||
<use xlink:href="#path-1"></use>
|
||||
</mask>
|
||||
<use id="形状" fill="#000000" xlink:href="#path-1"></use>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 1.3 KiB |
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
<title>Public/ic_public_close</title>
|
||||
<defs>
|
||||
<path d="M12,1 C18.0751322,1 23,5.92486775 23,12 C23,18.0751322 18.0751322,23 12,23 C5.92486775,23 1,18.0751322 1,12 C1,5.92486775 5.92486775,1 12,1 Z M12,2.5 C6.75329488,2.5 2.5,6.75329488 2.5,12 C2.5,17.2467051 6.75329488,21.5 12,21.5 C17.2467051,21.5 21.5,17.2467051 21.5,12 C21.5,6.75329488 17.2467051,2.5 12,2.5 Z M8.81801948,7.75735931 L12.0007071,10.9386327 L15.1819805,7.75735931 C15.4748737,7.46446609 15.9497475,7.46446609 16.2426407,7.75735931 C16.5355339,8.05025253 16.5355339,8.52512627 16.2426407,8.81801948 L8.81801948,16.2426407 C8.52512627,16.5355339 8.05025253,16.5355339 7.75735931,16.2426407 C7.46446609,15.9497475 7.46446609,15.4748737 7.75735931,15.1819805 L10.9400469,11.9992929 L7.75735931,8.81801948 C7.46446609,8.52512627 7.46446609,8.05025253 7.75735931,7.75735931 C8.05025253,7.46446609 8.52512627,7.46446609 8.81801948,7.75735931 Z M13.767767,12.7071068 L16.2426407,15.1819805 C16.5355339,15.4748737 16.5355339,15.9497475 16.2426407,16.2426407 C15.9497475,16.5355339 15.4748737,16.5355339 15.1819805,16.2426407 L12.7071068,13.767767 L13.767767,12.7071068 Z" id="path-1"></path>
|
||||
</defs>
|
||||
<g id="Public/ic_public_close" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||
<mask id="mask-2" fill="white">
|
||||
<use xlink:href="#path-1"></use>
|
||||
</mask>
|
||||
<use id="形状结合" fill="#000000" fill-rule="nonzero" xlink:href="#path-1"></use>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 1.6 KiB |
@ -0,0 +1,28 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- Generator: Adobe Illustrator 18.1.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||
<svg version="1.1"
|
||||
id="图层_1"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||
x="0px"
|
||||
y="0px"
|
||||
viewBox="0 0 48 96"
|
||||
enable-background="new 0 0 48 96"
|
||||
xml:space="preserve">
|
||||
<path
|
||||
fill="#CCCCCC"
|
||||
d="M37.1,45.9l-22-22c-1.2-1.2-3.1-1.2-4.2,0c-1.2,1.2-1.2,3.1,0,4.2L30.8,48L10.9,67.9c-1.2,1.2-1.2,3.1,0,4.2
|
||||
c0.6,0.6,1.4,0.9,2.1,0.9s1.5-0.3,2.1-0.9l22-22C38.3,48.9,38.3,47.1,37.1,45.9z"/>
|
||||
<g>
|
||||
</g>
|
||||
<g>
|
||||
</g>
|
||||
<g>
|
||||
</g>
|
||||
<g>
|
||||
</g>
|
||||
<g>
|
||||
</g>
|
||||
<g>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 681 B |
BIN
application/src/main/resources/base/media/icon.png
Normal file
After Width: | Height: | Size: 6.6 KiB |
BIN
application/src/main/resources/base/media/startIcon.png
Normal file
After Width: | Height: | Size: 4.2 KiB |
10
application/src/main/resources/base/profile/main_pages.json
Normal file
@ -0,0 +1,10 @@
|
||||
{
|
||||
"src": [
|
||||
"pages/certManagerFa",
|
||||
"pages/certPwdInput",
|
||||
"pages/trustedCa",
|
||||
"pages/cerEvidenceFa",
|
||||
"pages/requestAuth",
|
||||
"pages/certInstallAliasInput"
|
||||
]
|
||||
}
|
286
application/src/main/resources/en_US/element/string.json
Normal file
@ -0,0 +1,286 @@
|
||||
{
|
||||
"string": [
|
||||
{
|
||||
"name": "entry_MainAbility",
|
||||
"value": "Certificate Manager"
|
||||
},
|
||||
{
|
||||
"name": "mainability_description",
|
||||
"value": "ETS_Empty Feature Ability"
|
||||
},
|
||||
{
|
||||
"name": "version",
|
||||
"value": "Version "
|
||||
},
|
||||
{
|
||||
"name": "certificateTab",
|
||||
"value": "Certificate and Credential"
|
||||
},
|
||||
{
|
||||
"name": "certificateManage",
|
||||
"value": "Certificate Manager"
|
||||
},
|
||||
{
|
||||
"name": "trustedEvidence",
|
||||
"value": "Trusted Certificate"
|
||||
},
|
||||
{
|
||||
"name": "userEvidence",
|
||||
"value": "Credential List"
|
||||
},
|
||||
{
|
||||
"name": "installInStorageDevice",
|
||||
"value": "Install From Storage"
|
||||
},
|
||||
{
|
||||
"name": "installCertificateFailed",
|
||||
"value": "Install From Storage Failed"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdTab",
|
||||
"value": "Get Certificated"
|
||||
},
|
||||
{
|
||||
"name": "certificateAliasTab",
|
||||
"value": "Set Certificated"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdInfo",
|
||||
"value": "Input Password"
|
||||
},
|
||||
{
|
||||
"name": "certificateAliasInfo",
|
||||
"value": "Input Certificate Alias"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCred",
|
||||
"value": "Delete All Credentials and Certificates"
|
||||
},
|
||||
|
||||
|
||||
{
|
||||
"name": "deleteAllCredDialogTitle",
|
||||
"value": "Delete All Credentials and Certificates"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredDialogMessage",
|
||||
"value": "All credentials and certificates will be deleted. Whether or not to delete?"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredCancel",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCredDelete",
|
||||
"value": "Delete"
|
||||
},
|
||||
{
|
||||
"name": "pickCredToAuth",
|
||||
"value": "Select credential"
|
||||
},
|
||||
{
|
||||
"name": "requestAuthMsg",
|
||||
"value": "Application \"%s\" Request a certificate. Selecting a certificate allows the app to use this identity credential for the server. The app has identified the requested service as \"localhost\", You should only grant permission to use certificates to trusted apps."
|
||||
},
|
||||
{
|
||||
"name": "requestAuthCancel",
|
||||
"value": "Reject"
|
||||
},
|
||||
{
|
||||
"name": "requestAuthFinish",
|
||||
"value": "Authorize"
|
||||
},
|
||||
{
|
||||
"name": "requestFailPromptMsg",
|
||||
"value": "Authorize failed , invalid AppUid"
|
||||
},
|
||||
{
|
||||
"name": "installPwdInputCancel",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "installPwdInputConfirm",
|
||||
"value": "Extract"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputCancel",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputConfirm",
|
||||
"value": "Confirm"
|
||||
},
|
||||
{
|
||||
"name": "installAliasInputInfo",
|
||||
"value": "Attention: This certificate issuer may check all traffic entering and leaving the device\nThe packets contain:CA certificate"
|
||||
},
|
||||
{
|
||||
"name": "managerAuthApp",
|
||||
"value": "Manage Authorized Applications"
|
||||
},
|
||||
{
|
||||
"name": "cancelAuthApp",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "finishAuthApp",
|
||||
"value": "Finish"
|
||||
},
|
||||
{
|
||||
"name": "evidenceDetails",
|
||||
"value": "Credential details"
|
||||
},
|
||||
{
|
||||
"name": "entryContains",
|
||||
"value": "This item contains:"
|
||||
},
|
||||
{
|
||||
"name": "keyNum",
|
||||
"value": " %s user keys"
|
||||
},
|
||||
{
|
||||
"name": "userCerNum",
|
||||
"value": " %s user certificates"
|
||||
},
|
||||
{
|
||||
"name": "privateDetailsClose",
|
||||
"value": "Close"
|
||||
},
|
||||
{
|
||||
"name": "publicDetailsCancel",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "publicDetailsDelete",
|
||||
"value": "Delete"
|
||||
},
|
||||
{
|
||||
"name": "warning_title",
|
||||
"value": "Delete certificate"
|
||||
},
|
||||
{
|
||||
"name": "warning_message",
|
||||
"value": "After deletion, the application authorized with this certificate will not work normally. Whether or not to delete?"
|
||||
},
|
||||
{
|
||||
"name": "warning_cancel",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "warning_delete",
|
||||
"value": "Delete"
|
||||
},
|
||||
{
|
||||
"name": "tabName_public",
|
||||
"value": "Public"
|
||||
},
|
||||
{
|
||||
"name": "tabName_private",
|
||||
"value": "Private"
|
||||
},
|
||||
{
|
||||
"name": "system",
|
||||
"value": "System"
|
||||
},
|
||||
{
|
||||
"name": "user",
|
||||
"value": "User"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_firText",
|
||||
"value": "Certificate Detail"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_firListItem_text",
|
||||
"value": "Issued to:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_secListItem_text",
|
||||
"value": "Issued by:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_thdListItem_text",
|
||||
"value": "Validity:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_text",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_on",
|
||||
"value": "Enable"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_Button_off",
|
||||
"value": "Disable"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Status_true",
|
||||
"value": "Enabled"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Status_false",
|
||||
"value": "Disabled"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_firButton_text",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_Flex_secButton_text",
|
||||
"value": "Delete"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_text",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_title_text",
|
||||
"value": "Delete certificate"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_Button_message_text",
|
||||
"value": "After deletion, the application authorized with this certificate will not work normally. Whether or not to delete?"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_firButton_text",
|
||||
"value": "Cancel"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExampleUser_warning_secButton_text",
|
||||
"value": "Delete"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_firText",
|
||||
"value": "Common name:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_secText",
|
||||
"value": "Organization:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_thdText",
|
||||
"value": "Organizational unit:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_fouText",
|
||||
"value": "Serial number:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_fifText",
|
||||
"value": "Issued on:"
|
||||
},
|
||||
{
|
||||
"name": "DialogSubjectComponent_sixText",
|
||||
"value": "Expires on:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_fouListItem_text",
|
||||
"value": "Fingerprints:"
|
||||
},
|
||||
{
|
||||
"name": "CustomDialogExample_FingerPrint_text",
|
||||
"value": "SHA-256 fingerprints:"
|
||||
}
|
||||
]
|
||||
}
|
1008
application/src/main/resources/phone/element/float.json
Normal file
48
application/src/main/resources/phone/element/string.json
Normal file
@ -0,0 +1,48 @@
|
||||
{
|
||||
"string": [
|
||||
{
|
||||
"name": "entry_MainAbility",
|
||||
"value": "证书管理"
|
||||
},
|
||||
{
|
||||
"name": "mainability_description",
|
||||
"value": "ETS_Empty Feature Ability"
|
||||
},
|
||||
{
|
||||
"name": "certificateTab",
|
||||
"value": "证书与凭据"
|
||||
},
|
||||
{
|
||||
"name": "certificateManage",
|
||||
"value": "证书管理"
|
||||
},
|
||||
{
|
||||
"name": "trustedEvidence",
|
||||
"value": "受信任的证书"
|
||||
},
|
||||
{
|
||||
"name": "userEvidence",
|
||||
"value": "凭据列表"
|
||||
},
|
||||
{
|
||||
"name": "installInStorageDevice",
|
||||
"value": "从存储设备安装"
|
||||
},
|
||||
{
|
||||
"name": "installCertificateFailed",
|
||||
"value": "从存储设备安装失败"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdTab",
|
||||
"value": "提取证书"
|
||||
},
|
||||
{
|
||||
"name": "certificatePwdInfo",
|
||||
"value": "输入证书密码以提取"
|
||||
},
|
||||
{
|
||||
"name": "deleteAllCred",
|
||||
"value": "删除所有证书与凭据"
|
||||
}
|
||||
]
|
||||
}
|
16
application/src/main/resources/zh_CN/element/string.json
Normal file
@ -0,0 +1,16 @@
|
||||
{
|
||||
"string": [
|
||||
{
|
||||
"name": "module_desc",
|
||||
"value": "模块描述"
|
||||
},
|
||||
{
|
||||
"name": "ApplicationAbility_desc",
|
||||
"value": "description"
|
||||
},
|
||||
{
|
||||
"name": "ApplicationAbility_label",
|
||||
"value": "label"
|
||||
}
|
||||
]
|
||||
}
|
@ -1,18 +1,3 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
{
|
||||
"app": {
|
||||
"signingConfigs": [
|
||||
@ -66,8 +51,8 @@
|
||||
]
|
||||
},
|
||||
{
|
||||
"name": "phone",
|
||||
"srcPath": "./CertificateManager/product/phone",
|
||||
"name": "application",
|
||||
"srcPath": "./application",
|
||||
"targets": [
|
||||
{
|
||||
"name": "default",
|
||||
|
@ -1,18 +1,3 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
{
|
||||
"license": "",
|
||||
"devDependencies": {},
|
||||
|
@ -1,18 +1,3 @@
|
||||
/**
|
||||
* Copyright (c) 2022-2023 Huawei Device Co., Ltd.
|
||||
* 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.
|
||||
*/
|
||||
|
||||
{
|
||||
"license": "",
|
||||
"devDependencies": {
|
||||
|