Eftersom det du försöker göra är en självassociation behöver du bara ringa hasMany en gång, vilket kommer att skapa en kopplingstabell
User.hasMany(User, { as: 'Contacts', joinTableName: 'userHasContacts'})
Vilket skapar tabellen userHasContacts som:
CREATE TABLE IF NOT EXISTS `userHasContacts` (`userId` INTEGER , `ContactsId` INTEGER , `createdAt` DATETIME NOT NULL, `updatedAt` DATETIME NOT NULL, PRIMARY KEY (`userId`,`ContactsId`)) ENGINE=InnoDB;
För att hitta användare och deras kontakter kan du sedan göra:
User.find({ where: ..., include: [{model: User, as: 'Contacts'}]})