10f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)// Copyright 2013 The Chromium Authors. All rights reserved. 20f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 30f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)// found in the LICENSE file. 40f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 50f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "net/test/ct_test_util.h" 60f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 70f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include <string> 80f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include <vector> 90f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 100f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "base/strings/string_number_conversions.h" 110f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "base/strings/string_piece.h" 120f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "base/strings/string_util.h" 130f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "net/cert/ct_serialization.h" 140f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "net/cert/signed_certificate_timestamp.h" 15cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#include "net/cert/signed_tree_head.h" 160f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)#include "net/cert/x509_certificate.h" 170f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 180f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)namespace net { 190f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 200f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)namespace ct { 210f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 220f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)namespace { 230f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 240f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)std::string HexToBytes(const char* hex_data) { 250f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) std::vector<uint8> output; 260f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) std::string result; 270f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) if (base::HexStringToBytes(hex_data, &output)) 280f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) result.assign(reinterpret_cast<const char*>(&output[0]), output.size()); 290f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) return result; 300f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} 310f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 320f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)// The following test vectors are from 330f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)// http://code.google.com/p/certificate-transparency 340f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 350f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)const char kDefaultDerCert[] = 360f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "308202ca30820233a003020102020106300d06092a864886f70d01010505003055310b3009" 370f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "06035504061302474231243022060355040a131b4365727469666963617465205472616e73" 380f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "706172656e6379204341310e300c0603550408130557616c65733110300e06035504071307" 390f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "4572772057656e301e170d3132303630313030303030305a170d3232303630313030303030" 400f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "305a3052310b30090603550406130247423121301f060355040a1318436572746966696361" 410f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "7465205472616e73706172656e6379310e300c0603550408130557616c65733110300e0603" 420f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "55040713074572772057656e30819f300d06092a864886f70d010101050003818d00308189" 430f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "02818100b1fa37936111f8792da2081c3fe41925008531dc7f2c657bd9e1de4704160b4c9f" 440f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "19d54ada4470404c1c51341b8f1f7538dddd28d9aca48369fc5646ddcc7617f8168aae5b41" 450f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "d43331fca2dadfc804d57208949061f9eef902ca47ce88c644e000f06eeeccabdc9dd2f68a" 460f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "22ccb09dc76e0dbc73527765b1a37a8c676253dcc10203010001a381ac3081a9301d060355" 470f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "1d0e041604146a0d982a3b62c44b6d2ef4e9bb7a01aa9cb798e2307d0603551d2304763074" 480f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "80145f9d880dc873e654d4f80dd8e6b0c124b447c355a159a4573055310b30090603550406" 490f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "1302474231243022060355040a131b4365727469666963617465205472616e73706172656e" 500f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "6379204341310e300c0603550408130557616c65733110300e060355040713074572772057" 510f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "656e82010030090603551d1304023000300d06092a864886f70d010105050003818100171c" 520f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "d84aac414a9a030f22aac8f688b081b2709b848b4e5511406cd707fed028597a9faefc2eee" 530f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "2978d633aaac14ed3235197da87e0f71b8875f1ac9e78b281749ddedd007e3ecf50645f8cb" 540f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "f667256cd6a1647b5e13203bb8582de7d6696f656d1c60b95f456b7fcf338571908f1c6972" 550f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "7d24c4fccd249295795814d1dac0e6"; 560f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 57f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)const char kDefaultIssuerKeyHash[] = 58f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "02adddca08b8bf9861f035940c940156d8350fdff899a6239c6bd77255b8f8fc"; 590f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 600f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)const char kDefaultDerTbsCert[] = 610f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "30820233a003020102020107300d06092a864886f70d01010505003055310b300906035504" 620f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "061302474231243022060355040a131b4365727469666963617465205472616e7370617265" 630f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "6e6379204341310e300c0603550408130557616c65733110300e0603550407130745727720" 640f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "57656e301e170d3132303630313030303030305a170d3232303630313030303030305a3052" 650f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "310b30090603550406130247423121301f060355040a131843657274696669636174652054" 660f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "72616e73706172656e6379310e300c0603550408130557616c65733110300e060355040713" 670f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "074572772057656e30819f300d06092a864886f70d010101050003818d0030818902818100" 68f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "beef98e7c26877ae385f75325a0c1d329bedf18faaf4d796bf047eb7e1ce15c95ba2f80ee4" 69f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "58bd7db86f8a4b252191a79bd700c38e9c0389b45cd4dc9a120ab21e0cb41cd0e72805a410" 70f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "cd9c5bdb5d4927726daf1710f60187377ea25b1a1e39eed0b88119dc154dc68f7da8e30caf" 71f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "158a33e6c9509f4a05b01409ff5dd87eb50203010001a381ac3081a9301d0603551d0e0416" 72f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "04142031541af25c05ffd8658b6843794f5e9036f7b4307d0603551d230476307480145f9d" 73f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "880dc873e654d4f80dd8e6b0c124b447c355a159a4573055310b3009060355040613024742" 740f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "31243022060355040a131b4365727469666963617465205472616e73706172656e63792043" 750f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "41310e300c0603550408130557616c65733110300e060355040713074572772057656e8201" 760f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "0030090603551d1304023000"; 770f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 780f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)const char kTestDigitallySigned[] = 790f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "0403004730450220606e10ae5c2d5a1b0aed49dc4937f48de71a4e9784e9c208dfbfe9ef53" 800f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "6cf7f2022100beb29c72d7d06d61d06bdb38a069469aa86fe12e18bb7cc45689a2c0187ef5" 810f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "a5"; 820f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 830f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)const char kTestSignedCertificateTimestamp[] = 840f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "00df1c2ec11500945247a96168325ddc5c7959e8f7c6d388fc002e0bbd3f74d7640000013d" 850f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "db27ded900000403004730450220606e10ae5c2d5a1b0aed49dc4937f48de71a4e9784e9c2" 860f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "08dfbfe9ef536cf7f2022100beb29c72d7d06d61d06bdb38a069469aa86fe12e18bb7cc456" 870f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) "89a2c0187ef5a5"; 880f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 89f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)const char kEcP256PublicKey[] = 90f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "3059301306072a8648ce3d020106082a8648ce3d0301070342000499783cb14533c0161a5a" 91f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "b45bf95d08a29cd0ea8dd4c84274e2be59ad15c676960cf0afa1074a57ac644b23479e5b3f" 92f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "b7b245eb4b420ef370210371a944beaceb"; 93f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 94f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)const char kTestKeyId[] = 95f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "df1c2ec11500945247a96168325ddc5c7959e8f7c6d388fc002e0bbd3f74d764"; 96f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 97f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)const char kTestSCTSignatureData[] = 98f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "30450220606e10ae5c2d5a1b0aed49dc4937f48de71a4e9784e9c208dfbfe9ef536cf7f202" 99f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "2100beb29c72d7d06d61d06bdb38a069469aa86fe12e18bb7cc45689a2c0187ef5a5"; 100f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 101f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)const char kTestSCTPrecertSignatureData[] = 102f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "30450220482f6751af35dba65436be1fd6640f3dbf9a41429495924530288fa3e5e23e0602" 103f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "2100e4edc0db3ac572b1e2f5e8ab6a680653987dcf41027dfeffa105519d89edbf08"; 104f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 1055d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// A well-formed OCSP response with fake SCT contents. Does not come from 1065d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// http://code.google.com/p/certificate-transparency, does not pertain to any 1075d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// of the test certs here, and is only used to test extracting the extension 1085d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)// contents from the response. 1095d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)const char kFakeOCSPResponse[] = 1105d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "3082016e0a0100a08201673082016306092b060105050730010104820154308201503081ba" 1115d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "a21604144edfdf5ff9c90ffacfca66e7fbc436bc39ee3fc7180f3230313030313031303630" 1125d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "3030305a30818e30818b3049300906052b0e03021a050004141833a1e6a4f09577cca0e64c" 1135d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "e7d145ca4b93700904144edfdf5ff9c90ffacfca66e7fbc436bc39ee3fc7021001aef99bde" 1145d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "e0bb58c6f2b816bc3ae02f8000180f32303130303130313036303030305aa011180f323033" 1155d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "30303130313036303030305aa11830163014060a2b06010401d67902040504060404746573" 1165d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "74300d06092a864886f70d0101050500038181003586ffcf0794e64eb643d52a3d570a1c93" 1175d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "836395986a2f792dd4e9c70b05161186c55c1658e0607dc9ec0d0924ac37fb99506c870579" 1185d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "634be1de62ba2fced5f61f3b428f959fcee9bddf6f268c8e14c14fdf3b447786e638a5c8cc" 1195d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "b610893df17a60e4cff30f4780aeffe0086ef19910f0d9cd7414bc93d1945686f88ad0a3c3" 1205d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) ; 1215d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 1225d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)const char kFakeOCSPResponseCert[] = 1235d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "3082022930820192a003020102021001aef99bdee0bb58c6f2b816bc3ae02f300d06092a86" 1245d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "4886f70d01010505003015311330110603550403130a54657374696e67204341301e170d31" 1255d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "30303130313036303030305a170d3332313230313036303030305a30373112301006035504" 1265d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "0313093132372e302e302e31310b300906035504061302585831143012060355040a130b54" 1275d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "657374696e67204f726730819d300d06092a864886f70d010101050003818b003081870281" 1285d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "8100a71998f2930bfe73d031a87f133d2f378eeeeed52a77e44d0fc9ff6f07ff32cbf3da99" 1295d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "9de4ed65832afcb0807f98787506539d258a0ce3c2c77967653099a9034a9b115a876c39a8" 1305d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "c4e4ed4acd0c64095946fb39eeeb47a0704dbb018acf48c3a1c4b895fc409fb4a340a986b1" 1315d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "afc45519ab9eca47c30185c771c64aa5ecf07d020103a35a3058303a06082b060105050701" 1325d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "01010100042b3029302706082b06010505073001861b687474703a2f2f3132372e302e302e" 1335d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "313a35353038312f6f637370301a0603551d200101000410300e300c060a2b06010401d679" 1345d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "020401300d06092a864886f70d01010505000381810065e04fadd3484197f3412479d917e1" 1355d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "9d8f7db57b526f2d0e4c046f86cebe643bf568ea0cd6570b228842aa057c6a7c79f209dfcd" 1365d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "3419a4d93b1ecfb1c0224f33083c7d4da023499fbd00d81d6711ad58ffcf65f1545247fe9d" 1375d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "83203425fd706b4fc5e797002af3d88151be5901eef56ec30aacdfc404be1bd35865ff1943" 1385d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "2516"; 1395d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 1405d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)const char kFakeOCSPResponseIssuerCert[] = 1415d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "308201d13082013aa003020102020101300d06092a864886f70d0101050500301531133011" 1425d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "0603550403130a54657374696e67204341301e170d3130303130313036303030305a170d33" 1435d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "32313230313036303030305a3015311330110603550403130a54657374696e672043413081" 1445d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "9d300d06092a864886f70d010101050003818b0030818702818100a71998f2930bfe73d031" 1455d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "a87f133d2f378eeeeed52a77e44d0fc9ff6f07ff32cbf3da999de4ed65832afcb0807f9878" 1465d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "7506539d258a0ce3c2c77967653099a9034a9b115a876c39a8c4e4ed4acd0c64095946fb39" 1475d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "eeeb47a0704dbb018acf48c3a1c4b895fc409fb4a340a986b1afc45519ab9eca47c30185c7" 1485d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "71c64aa5ecf07d020103a333303130120603551d130101ff040830060101ff020100301b06" 1495d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "03551d200101000411300f300d060b2b06010401d6790201ce0f300d06092a864886f70d01" 1505d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "01050500038181003f4936f8d00e83fbdde331f2c64335dcf7dec8b1a2597683edeed61af0" 1515d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "fa862412fad848938fe7ab77f1f9a43671ff6fdb729386e26f49e7aca0c0ea216e5970d933" 1525d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "3ea1e11df2ccb357a5fed5220f9c6239e8946b9b7517707631d51ab996833d58a022cff5a6" 1535d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) "2169ac9258ec110efee78da9ab4a641e3b3c9ee5e8bd291460"; 1545d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 1555d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 1565d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)const char kFakeOCSPExtensionValue[] = "74657374"; // "test" 1575d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 158cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// For the sample STH 159cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)const char kSampleSTHSHA256RootHash[] = 160cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) "726467216167397babca293dca398e4ce6b621b18b9bc42f30c900d1f92ac1e4"; 161cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)const char kSampleSTHTreeHeadSignature[] = 162cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) "0403004730450220365a91a2a88f2b9332f41d8959fa7086da7e6d634b7b089bc9da066426" 163cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) "6c7a20022100e38464f3c0fd066257b982074f7ac87655e0c8f714768a050b4be9a7b441cb" 164cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) "d3"; 165cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 1660f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} // namespace 1670f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 1680f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)void GetX509CertLogEntry(LogEntry* entry) { 1690f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) entry->type = ct::LogEntry::LOG_ENTRY_TYPE_X509; 1700f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) entry->leaf_certificate = HexToBytes(kDefaultDerCert); 1710f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} 1720f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 173f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)std::string GetDerEncodedX509Cert() { return HexToBytes(kDefaultDerCert); } 174f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 1750f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)void GetPrecertLogEntry(LogEntry* entry) { 1760f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) entry->type = ct::LogEntry::LOG_ENTRY_TYPE_PRECERT; 177f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) std::string issuer_hash(HexToBytes(kDefaultIssuerKeyHash)); 1780f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) memcpy(entry->issuer_key_hash.data, issuer_hash.data(), issuer_hash.size()); 1790f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) entry->tbs_certificate = HexToBytes(kDefaultDerTbsCert); 1800f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} 1810f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 1820f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)std::string GetTestDigitallySigned() { 1830f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) return HexToBytes(kTestDigitallySigned); 1840f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} 1850f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 1860f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)std::string GetTestSignedCertificateTimestamp() { 1870f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) return HexToBytes(kTestSignedCertificateTimestamp); 1880f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} 1890f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 190f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)std::string GetTestPublicKey() { 191f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) return HexToBytes(kEcP256PublicKey); 192f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 193f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 194f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)std::string GetTestPublicKeyId() { 195f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) return HexToBytes(kTestKeyId); 196f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 197f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 198f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)void GetX509CertSCT(scoped_refptr<SignedCertificateTimestamp>* sct_ref) { 199f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) CHECK(sct_ref != NULL); 200f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) *sct_ref = new SignedCertificateTimestamp(); 201f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) SignedCertificateTimestamp *const sct(sct_ref->get()); 202a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles) sct->version = ct::SignedCertificateTimestamp::SCT_VERSION_1; 203f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->log_id = HexToBytes(kTestKeyId); 204f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Time the log issued a SCT for this certificate, which is 205f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Fri Apr 5 10:04:16.089 2013 206f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->timestamp = base::Time::UnixEpoch() + 207f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) base::TimeDelta::FromMilliseconds(GG_INT64_C(1365181456089)); 208f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->extensions.clear(); 209f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 210f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.hash_algorithm = ct::DigitallySigned::HASH_ALGO_SHA256; 211f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.signature_algorithm = ct::DigitallySigned::SIG_ALGO_ECDSA; 212f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.signature_data = HexToBytes(kTestSCTSignatureData); 213f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 214f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 215f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)void GetPrecertSCT(scoped_refptr<SignedCertificateTimestamp>* sct_ref) { 216f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) CHECK(sct_ref != NULL); 217f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) *sct_ref = new SignedCertificateTimestamp(); 218f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) SignedCertificateTimestamp *const sct(sct_ref->get()); 219a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles) sct->version = ct::SignedCertificateTimestamp::SCT_VERSION_1; 220f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->log_id = HexToBytes(kTestKeyId); 221f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Time the log issued a SCT for this Precertificate, which is 222f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Fri Apr 5 10:04:16.275 2013 223f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->timestamp = base::Time::UnixEpoch() + 224f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) base::TimeDelta::FromMilliseconds(GG_INT64_C(1365181456275)); 225f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->extensions.clear(); 226f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 227f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.hash_algorithm = ct::DigitallySigned::HASH_ALGO_SHA256; 228f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.signature_algorithm = ct::DigitallySigned::SIG_ALGO_ECDSA; 229f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) sct->signature.signature_data = HexToBytes(kTestSCTPrecertSignatureData); 230f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 231f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 232f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)std::string GetDefaultIssuerKeyHash() { 233f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) return HexToBytes(kDefaultIssuerKeyHash); 234f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 235f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 2365d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)std::string GetDerEncodedFakeOCSPResponse() { 2375d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)return HexToBytes(kFakeOCSPResponse); 2385d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)} 2395d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 2405d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)std::string GetFakeOCSPExtensionValue() { 2415d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) return HexToBytes(kFakeOCSPExtensionValue); 2425d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)} 2435d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 2445d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)std::string GetDerEncodedFakeOCSPResponseCert() { 2455d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) return HexToBytes(kFakeOCSPResponseCert); 2465d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)} 2475d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 2485d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)std::string GetDerEncodedFakeOCSPResponseIssuerCert() { 2495d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) return HexToBytes(kFakeOCSPResponseIssuerCert); 2505d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)} 2515d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 252cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)std::string GetSampleSTHSHA256RootHash() { 253cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) return HexToBytes(kSampleSTHSHA256RootHash); 254cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)} 255cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 256cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// A sample, valid STH 257cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)void GetSignedTreeHead(SignedTreeHead* sth) { 258cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) sth->version = SignedTreeHead::V1; 259cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) sth->timestamp = base::Time::UnixEpoch() + 260cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) base::TimeDelta::FromMilliseconds(1396877277237); 261cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) sth->tree_size = 21u; 262cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) std::string sha256_root_hash = GetSampleSTHSHA256RootHash(); 263cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) memcpy(sth->sha256_root_hash, sha256_root_hash.c_str(), kSthRootHashLength); 264cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 265cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) std::string tree_head_signature = HexToBytes(kSampleSTHTreeHeadSignature); 266cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) base::StringPiece sp(tree_head_signature); 267cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) DecodeDigitallySigned(&sp, &(sth->signature)); 268cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)} 269cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 2700f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} // namespace ct 2710f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles) 2720f1bc08d4cfcc34181b0b5cbf065c40f687bf740Torne (Richard Coles)} // namespace net 273