|
|
|
'use strict';
|
|
|
|
var common = require('../common');
|
|
|
|
var assert = require('assert');
|
|
|
|
|
|
|
|
var util = require('util');
|
|
|
|
var net = require('net');
|
|
|
|
var fs = require('fs');
|
|
|
|
var crypto = require('crypto');
|
|
|
|
|
|
|
|
var keyPem = fs.readFileSync(common.fixturesDir + '/cert.pem');
|
|
|
|
var certPem = fs.readFileSync(common.fixturesDir + '/cert.pem');
|
|
|
|
|
|
|
|
try {
|
|
|
|
var credentials = crypto.createCredentials({key: keyPem, cert: certPem});
|
|
|
|
} catch (e) {
|
|
|
|
common.skip('node compiled without OpenSSL.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var i = 0;
|
|
|
|
var server = net.createServer(function(connection) {
|
|
|
|
connection.setSecure(credentials);
|
|
|
|
connection.setEncoding('binary');
|
|
|
|
|
|
|
|
connection.on('secure', function() {
|
|
|
|
//console.log('Secure');
|
|
|
|
});
|
|
|
|
|
|
|
|
connection.on('data', function(chunk) {
|
|
|
|
console.log('recved: ' + JSON.stringify(chunk));
|
|
|
|
connection.write('HTTP/1.0 200 OK\r\n' +
|
|
|
|
'Content-type: text/plain\r\n' +
|
|
|
|
'Content-length: 9\r\n' +
|
|
|
|
'\r\n' +
|
|
|
|
'OK : ' + i +
|
|
|
|
'\r\n\r\n');
|
|
|
|
i = i + 1;
|
|
|
|
connection.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
connection.on('end', function() {
|
|
|
|
connection.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
server.listen(4443);
|
|
|
|
|
|
|
|
|