Skip to main content

ContactSelf

Bot itself will be encapsulated as a ContactSelf. This class is extends Contact.

ContactSelf

Bot itself will be encapsulated as a ContactSelf.

Tips: this class is extends Contact

Kind: global class

contactSelf.avatar([file])Promise <void | FileBox>

GET / SET bot avatar

Kind: instance method of ContactSelf

ParamType
[file]FileBox

Example ( GET the avatar for bot, return {Promise<FileBox>})

// Save avatar to local file like `1-name.jpg`

bot.on('login', async user => {
console.log(`user ${user} login`)
const file = await user.avatar()
const name = file.name
await file.toFile(name, true)
console.log(`Save bot avatar: ${user.name()} with avatar file: ${name}`)
})

Example (SET the avatar for a bot)

import { FileBox }  from 'file-box'
bot.on('login', user => {
console.log(`user ${user} login`)
const fileBox = FileBox.fromUrl('https://wechaty.github.io/wechaty/images/bot-qr-code.png')
await user.avatar(fileBox)
console.log(`Change bot avatar successfully!`)
})

contactSelf.qrcode()Promise <string>

Get bot qrcode

Kind: instance method of ContactSelf

Example

import { generate } from 'qrcode-terminal'
bot.on('login', async user => {
console.log(`user ${user} login`)
const qrcode = await user.qrcode()
console.log(`Following is the bot qrcode!`)
generate(qrcode, { small: true })
})

contactSelf.signature(signature)Promise <void>

Change bot signature

Kind: instance method of ContactSelf

ParamDescription
signatureThe new signature that the bot will change to

Example

bot.on('login', async user => {
console.log(`user ${user} login`)
try {
await user.signature(`Signature changed by wechaty on ${new Date()}`)
} catch (e) {
console.error('change signature failed', e)
}
})

contactSelf.name([name])Promise<void> | string

Get or change bot name.

Kind: instance method of ContactSelf

ParamDescription
[name]The new alias that the bot will change to

Example

bot.on('login', async user => {
console.log(`user ${user} login`)
const oldName = user.name() // get bot name
try {
await user.name(`${oldName}-${new Date().getTime()}`) // change bot name
} catch (e) {
console.error('change name failed', e)
}
})