hana-cli
Version:
HANA Developer Command Line Interface
56 lines (50 loc) • 1.69 kB
JavaScript
// @ts-check
import * as base from '../utils/base.js'
export const command = 'createXSAAdmin [user] [password]'
export const aliases = ['cXSAAdmin', 'cXSAA', 'cxsaadmin', 'cxsaa']
export const describe = base.bundle.getText("createXSAAdmin")
export const builder = base.getBuilder({
user: {
alias: ['u', 'User'],
desc: base.bundle.getText("user")
},
password: {
alias: ['p', 'Password'],
desc: base.bundle.getText("password")
}
})
export function handler (argv) {
base.promptHandler(argv, activate, {
user: {
description: base.bundle.getText("user"),
required: true
},
password: {
description: base.bundle.getText("password"),
hidden: true,
replace: '*',
required: true
}
})
}
export async function activate(prompts) {
base.debug('activate')
try {
base.setPrompts(prompts)
const dbStatus = await base.createDBConnection()
let results = await dbStatus.execSQL(`CREATE USER ${prompts.user} PASSWORD "${prompts.password}" NO FORCE_FIRST_PASSWORD_CHANGE;`)
console.table(results)
let resultsGrant = await dbStatus.execSQL(
`ALTER USER ${prompts.user} DISABLE PASSWORD LIFETIME;`)
console.table(resultsGrant)
resultsGrant = await dbStatus.execSQL(
`ALTER USER ${prompts.user} SET PARAMETER EMAIL ADDRESS = '${prompts.user}@sap.com';`)
console.table(resultsGrant)
resultsGrant = await dbStatus.execSQL(
`ALTER USER ${prompts.user} SET PARAMETER XS_RC_XS_CONTROLLER_ADMIN = 'XS_CONTROLLER_ADMIN';`)
console.table(resultsGrant)
return base.end()
} catch (error) {
base.error(error)
}
}