'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); const fixtures = require('../common/fixtures'); const https = require('https'); const crypto = require('crypto'); const options = { key: fixtures.readKey('agent1-key.pem'), cert: fixtures.readKey('agent1-cert.pem'), ca: fixtures.readKey('ca1-cert.pem') }; const server = https.createServer(options, function(req, res) { res.end('hello'); }); const aes = Buffer.alloc(16, 'S'); const hmac = Buffer.alloc(16, 'H'); server._sharedCreds.context.enableTicketKeyCallback(); server._sharedCreds.context.onticketkeycallback = function(name, iv, enc) { if (enc) { const newName = Buffer.alloc(16, 'A'); const newIV = crypto.randomBytes(16); return [ 1, hmac, aes, newName, newIV ]; } // Renew return [ 2, hmac, aes ]; }; server.listen(0, function() { const addr = this.address(); function doReq(callback) { https.request({ method: 'GET', port: addr.port, servername: 'agent1', ca: options.ca }, function(res) { res.resume(); res.once('end', callback); }).end(); } doReq(function() { doReq(function() { server.close(); }); }); });