import 'dart:convert'; import '../io_reply.dart'; import '../io_sender.dart'; import '../io_tool/io_tool.dart'; import '../io_type.dart'; import 'package:crypto/crypto.dart' as crypto; import '../sm4Encipher/sm4.dart'; ///TODO:该协议已弃用 使用新协议SenderAddICCardWithTimeCycleCoercionCommand 2024.4.16 addby 魏少阳 /// ///TODO:设置自定义密码 // /* // 备注: // 删除单个指纹规则:UseCountLimit 设置为 0。删除全部指纹规则: UseCountLimit 设置为 0,FingerNo 设置为 255,userId 设置为“Delete All !@#”,只有门锁管理员才有权限 // **/ // class SenderAddICCardCommand extends SenderProtocol { // String? keyID; // String? userID; // int? cardNo; // int? useCountLimit; // List? token; // int? startTime; // int? endTime; // int? needAuthor; // List? signKey; // List? privateKey; // // SenderAddICCardCommand({ // this.keyID, // this.userID, // this.cardNo, // this.useCountLimit, // this.token, // this.startTime, // this.endTime, // this.needAuthor, // this.signKey, // this.privateKey, // }) : super(CommandType.generalExtendedCommond); // // @override // List messageDetail() { // List data = []; // List subData = []; // List ebcData = []; // // // 指令类型 // int type = commandType!.typeValue; // double typeDouble = type / 256; // int type1 = typeDouble.toInt(); // int type2 = type % 256; // data.add(type1); // data.add(type2); // // // 子命令类型 // data.add(21); // // // keyID 40 // int keyIDLength = utf8.encode(keyID!).length; // subData.addAll(utf8.encode(keyID!)); // subData = getFixedLengthList(subData, 40 - keyIDLength); // // //userID 20 // int userIDLength = utf8.encode(userID!).length; // subData.addAll(utf8.encode(userID!)); // subData = getFixedLengthList(subData, 20 - userIDLength); // // // PwdNo // subData.add(cardNo!); // // // UseCountLimit // subData.add(useCountLimit!); // // // token // subData.addAll(token!); // // // startTime 4 // subData.add((startTime! & 0xff000000) >> 24); // subData.add((startTime! & 0xff0000) >> 16); // subData.add((startTime! & 0xff00) >> 8); // subData.add((startTime! & 0xff)); // // // endTime 4 // subData.add((endTime! & 0xff000000) >> 24); // subData.add((endTime! & 0xff0000) >> 16); // subData.add((endTime! & 0xff00) >> 8); // subData.add((endTime! & 0xff)); // // if (needAuthor == 0) { // //AuthCodeLen 1 // subData.add(0); // } else { // List authCodeData = []; // //KeyID // authCodeData.addAll(utf8.encode(keyID!)); // // //authUserID // authCodeData.addAll(utf8.encode(userID!)); // // //token 4 首次请求 Token 填 0,如果锁需要鉴权操作者身份,则会分配动态口令并在应答消息中返回,二次请求时带上。 // authCodeData.addAll(token!); // // authCodeData.addAll(signKey!); // // // 把KeyID、authUserID、时间戳、公钥通过md5加密之后就是authCode // var authCode = crypto.md5.convert(authCodeData); // // subData.add(authCode.bytes.length); // subData.addAll(authCode.bytes); // } // // data.add(subData.length); // data.addAll(subData); // // if ((data.length % 16) != 0) { // int add = (16 - data.length % 16); // for (int i = 0; i < add; i++) { // data.add(0); // } // } // // 拿到数据之后通过LockId进行SM4 ECB加密 key:544d485f633335373034383064613864 // ebcData = SM4.encrypt(data, key: privateKey, mode: SM4CryptoMode.ECB); // return ebcData; // } // } // // class SenderAddICCardReply extends Reply { // SenderAddICCardReply.parseData(CommandType commandType, List dataDetail) // : super.parseData(commandType, dataDetail) { // data = dataDetail; // } // } // // class SenderAddICCardConfirmationReply extends Reply { // SenderAddICCardConfirmationReply.parseData( // CommandType commandType, List dataDetail) // : super.parseData(commandType, dataDetail) { // data = dataDetail; // } // }