// Copyright 2018 AJ ONeal. All rights reserved
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
'use strict';

module.exports.run = function run(
	directoryUrl,
	RSA,
	web,
	chType,
	email,
	accountKeypair,
	domainKeypair
) {
	// [ 'test.ppl.family' ] 'coolaj86@gmail.com''http-01'
	var acme2 = require('../').ACME.create({ RSA: RSA });
	acme2.init(directoryUrl).then(function() {
		var options = {
			agreeToTerms: function(tosUrl, agree) {
				agree(null, tosUrl);
			},
			setChallenge: function(opts, cb) {
				var pathname;

				console.log('');
				console.log('identifier:');
				console.log(opts.identifier);
				console.log('hostname:');
				console.log(opts.hostname);
				console.log('type:');
				console.log(opts.type);
				console.log('token:');
				console.log(opts.token);
				console.log('thumbprint:');
				console.log(opts.thumbprint);
				console.log('keyAuthorization:');
				console.log(opts.keyAuthorization);
				console.log('dnsAuthorization:');
				console.log(opts.dnsAuthorization);
				console.log('');

				if ('http-01' === opts.type) {
					pathname =
						opts.hostname +
						acme2.challengePrefixes['http-01'] +
						'/' +
						opts.token;
					console.log(
						"Put the string '" +
							opts.keyAuthorization +
							"' into a file at '" +
							pathname +
							"'"
					);
					console.log(
						"echo '" + opts.keyAuthorization + "' > '" + pathname + "'"
					);
				} else if ('dns-01' === opts.type) {
					pathname =
						acme2.challengePrefixes['dns-01'] +
						'.' +
						opts.hostname.replace(/^\*\./, '');
					console.log(
						"Put the string '" +
							opts.dnsAuthorization +
							"' into the TXT record '" +
							pathname +
							"'"
					);
					console.log(
						'ddig TXT ' + pathname + " '" + opts.dnsAuthorization + "'"
					);
				} else {
					cb(new Error('[acme-v2] unrecognized challenge type'));
					return;
				}
				console.log("\nThen hit the 'any' key to continue...");

				function onAny() {
					console.log("'any' key was hit");
					process.stdin.pause();
					process.stdin.removeListener('data', onAny);
					process.stdin.setRawMode(false);
					cb();
				}

				process.stdin.setRawMode(true);
				process.stdin.resume();
				process.stdin.on('data', onAny);
			},
			removeChallenge: function(opts, cb) {
				// hostname, key
				console.log(
					'[acme-v2] remove challenge',
					opts.hostname,
					opts.keyAuthorization
				);
				setTimeout(cb, 1 * 1000);
			},
			challengeType: chType,
			email: email,
			accountKeypair: accountKeypair,
			domainKeypair: domainKeypair,
			domains: web
		};

		acme2.accounts.create(options).then(function(account) {
			console.log('[acme-v2] account:');
			console.log(account);

			acme2.certificates.create(options).then(function(fullchainPem) {
				console.log('[acme-v2] fullchain.pem:');
				console.log(fullchainPem);
			});
		});
	});
};