Skip to content

Commit

Permalink
Fixes logging in with passwordless certificate. Closes pnp#6337
Browse files Browse the repository at this point in the history
  • Loading branch information
milanholemans authored and waldekmastykarz committed Sep 15, 2024
1 parent 75281b4 commit 7717450
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 3 deletions.
63 changes: 61 additions & 2 deletions src/m365/commands/login.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,12 +53,12 @@ describe(commands.LOGIN, () => {
}
};
sinon.stub(auth.connection, 'deactivate').callsFake(() => { });
sinon.stub(auth, 'ensureAccessToken').callsFake(() => {
sinon.stub(auth, 'ensureAccessToken').callsFake(async () => {
auth.connection.name = '028de82d-7fd9-476e-a9fd-be9714280ff3';
auth.connection.identityName = '[email protected]';
auth.connection.identityId = '028de82d-7fd9-476e-a9fd-be9714280ff3';
auth.connection.identityTenantId = 'db308122-52f3-4241-af92-1734aa6e2e50';
return Promise.resolve('');
return '';
});
sinon.stub(config, 'get').returns(undefined);
});
Expand Down Expand Up @@ -162,6 +162,42 @@ describe(commands.LOGIN, () => {
assert.strictEqual(auth.connection.certificate, 'certificate', 'Incorrect certificate set');
});

it('logs in to Microsoft 365 using certificate when authType certificate set and certificate password is provided', async () => {
sinon.stub(fs, 'readFileSync').callsFake(() => 'certificate');
sinon.stub(fs, 'existsSync').callsFake(() => true);

await command.action(logger, {
options: commandOptionsSchema.parse({
appId: '00000000-0000-0000-0000-000000000000',
tenant: '00000000-0000-0000-0000-000000000000',
authType: 'certificate',
certificateFile: 'certificate',
password: 'p@$$w0rd'
})
});
assert.strictEqual(auth.connection.authType, AuthType.Certificate, 'Incorrect authType set');
assert.strictEqual(auth.connection.certificate, 'certificate', 'Incorrect certificate set');
assert.strictEqual(auth.connection.password, 'p@$$w0rd', 'Incorrect password set');
});

it('logs in to Microsoft 365 using certificate when authType certificate set and certificate password is empty', async () => {
sinon.stub(fs, 'readFileSync').callsFake(() => 'certificate');
sinon.stub(fs, 'existsSync').callsFake(() => true);

await command.action(logger, {
options: commandOptionsSchema.parse({
appId: '00000000-0000-0000-0000-000000000000',
tenant: '00000000-0000-0000-0000-000000000000',
authType: 'certificate',
certificateFile: 'certificate',
password: ''
})
});
assert.strictEqual(auth.connection.authType, AuthType.Certificate, 'Incorrect authType set');
assert.strictEqual(auth.connection.certificate, 'certificate', 'Incorrect certificate set');
assert.strictEqual(auth.connection.password, '', 'Incorrect password set');
});

it('logs in to Microsoft 365 using certificate when authType certificate set with thumbprint', async () => {
sinon.stub(fs, 'readFileSync').callsFake(() => 'certificate');
sinon.stub(fs, 'existsSync').callsFake(() => true);
Expand Down Expand Up @@ -218,6 +254,29 @@ describe(commands.LOGIN, () => {
assert.strictEqual(auth.connection.thumbprint, 'thumbprint', 'Incorrect thumbprint set');
});

it('logs in to Microsoft 365 using certificate when authType certificate set and clientCertificatePassword is set in CLI config', async () => {
sinonUtil.restore(config.get);
sinon.stub(config, 'get').callsFake(setting => {
if (setting === settingsNames.clientCertificateBase64Encoded) {
return 'certificate';
}
if (setting === settingsNames.clientCertificatePassword) {
return 'p@$$w0rd';
}
return undefined;
});
await command.action(logger, {
options: commandOptionsSchema.parse({
appId: '00000000-0000-0000-0000-000000000000',
tenant: '00000000-0000-0000-0000-000000000000',
authType: 'certificate'
})
});
assert.strictEqual(auth.connection.authType, AuthType.Certificate, 'Incorrect authType set');
assert.strictEqual(auth.connection.certificate, 'certificate', 'Incorrect certificate set');
assert.strictEqual(auth.connection.password, 'p@$$w0rd', 'Incorrect password set');
});

it('logs in to Microsoft 365 using certificate when authType certificate set and certificateFile is set in CLI config', async () => {
sinonUtil.restore(config.get);
sinon.stub(config, 'get').callsFake(setting => {
Expand Down
2 changes: 1 addition & 1 deletion src/m365/commands/login.ts
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ class LoginCommand extends Command {
auth.connection.authType = AuthType.Certificate;
auth.connection.certificate = getCertificate(args.options);
auth.connection.thumbprint = args.options.thumbprint;
auth.connection.password = args.options.password || cli.getConfig().get(settingsNames.clientCertificatePassword);
auth.connection.password = args.options.password ?? cli.getConfig().get(settingsNames.clientCertificatePassword);
break;
case 'identity':
auth.connection.authType = AuthType.Identity;
Expand Down

0 comments on commit 7717450

Please sign in to comment.