2018-07-10 23:01:34 +08:00
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
|
|
#include <fnd/types.h>
|
|
|
|
#include <fnd/IFile.h>
|
|
|
|
#include <fnd/Vec.h>
|
2018-08-06 16:59:56 +08:00
|
|
|
#include <pki/SignedData.h>
|
2018-08-06 19:36:42 +08:00
|
|
|
#include <pki/CertificateBody.h>
|
2018-07-10 23:01:34 +08:00
|
|
|
#include <es/TicketBody_V2.h>
|
|
|
|
#include "nstool.h"
|
|
|
|
|
|
|
|
class EsTikProcess
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
EsTikProcess();
|
|
|
|
~EsTikProcess();
|
|
|
|
|
|
|
|
void process();
|
|
|
|
|
|
|
|
void setInputFile(fnd::IFile* file, bool ownIFile);
|
|
|
|
void setKeyset(const sKeyset* keyset);
|
2018-08-06 19:36:42 +08:00
|
|
|
void setCertificateChain(const fnd::List<pki::SignedData<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";
|
|
|
|
|
|
|
|
fnd::IFile* mFile;
|
|
|
|
bool mOwnIFile;
|
|
|
|
const sKeyset* mKeyset;
|
|
|
|
CliOutputMode mCliOutputMode;
|
|
|
|
bool mVerify;
|
2018-08-06 19:36:42 +08:00
|
|
|
|
|
|
|
fnd::List<pki::SignedData<pki::CertificateBody>> mCerts;
|
2018-07-10 23:01:34 +08:00
|
|
|
|
2018-08-06 16:59:56 +08:00
|
|
|
pki::SignedData<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;
|
|
|
|
};
|