2018-07-10 23:01:34 +08:00
|
|
|
#pragma once
|
2021-09-28 19:15:54 +08:00
|
|
|
#include "types.h"
|
|
|
|
#include "KeyBag.h"
|
|
|
|
|
2018-08-07 15:17:51 +08:00
|
|
|
#include <nn/pki/SignedData.h>
|
|
|
|
#include <nn/pki/CertificateBody.h>
|
|
|
|
#include <nn/es/TicketBody_V2.h>
|
2021-09-28 19:15:54 +08:00
|
|
|
|
|
|
|
namespace nstool {
|
2018-07-10 23:01:34 +08:00
|
|
|
|
|
|
|
class EsTikProcess
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
EsTikProcess();
|
|
|
|
|
|
|
|
void process();
|
|
|
|
|
2021-09-28 19:15:54 +08:00
|
|
|
void setInputFile(const std::shared_ptr<tc::io::IStream>& file);
|
|
|
|
void setKeyCfg(const KeyBag& keycfg);
|
|
|
|
void setCertificateChain(const std::vector<nn::pki::SignedData<nn::pki::CertificateBody>>& certs);
|
2018-07-10 23:01:34 +08:00
|
|
|
void setCliOutputMode(CliOutputMode mode);
|
|
|
|
void setVerifyMode(bool verify);
|
|
|
|
|
|
|
|
private:
|
|
|
|
const std::string kModuleName = "EsTikProcess";
|
|
|
|
|
2021-09-28 19:15:54 +08:00
|
|
|
std::shared_ptr<tc::io::IStream> mFile;
|
|
|
|
KeyBag mKeyCfg;
|
2018-07-10 23:01:34 +08:00
|
|
|
CliOutputMode mCliOutputMode;
|
|
|
|
bool mVerify;
|
2018-08-06 19:36:42 +08:00
|
|
|
|
2021-09-28 19:15:54 +08:00
|
|
|
std::vector<nn::pki::SignedData<nn::pki::CertificateBody>> mCerts;
|
2018-07-10 23:01:34 +08:00
|
|
|
|
2018-08-07 16:13:18 +08:00
|
|
|
nn::pki::SignedData<nn::es::TicketBody_V2> mTik;
|
2018-07-10 23:01:34 +08:00
|
|
|
|
2018-08-06 19:36:42 +08:00
|
|
|
void importTicket();
|
|
|
|
void verifyTicket();
|
2018-07-10 23:01:34 +08:00
|
|
|
void displayTicket();
|
2018-07-29 21:01:11 +09:00
|
|
|
const char* getSignTypeStr(uint32_t type) const;
|
2018-07-10 23:01:34 +08:00
|
|
|
const char* getTitleKeyPersonalisationStr(byte_t flag) const;
|
|
|
|
const char* getLicenseTypeStr(byte_t flag) const;
|
|
|
|
const char* getPropertyFlagStr(byte_t flag) const;
|
2021-09-28 19:15:54 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|