Follow and unfollow a user / author.
This tutorial will take you through the process of checking the follow status
of an author and either follow or unfollow that user depending on the current status. This is done with the call
operation as well as the broadcast.json
operation.
We are using the broadcast.json
operation provided by the dsteem
library to follow or unfollow a selected author. There are 4 variables required to execute this operation:
- follower - The specific user that will select the author to follow/unfollow (
username
). - privatekey - This is the private posting key of the user(
postingKey
). - following - The account/author that the user would like to follow (
author
). - what - The
type
of follow operation. This variable can have one of two values:blog
, to follow an author, and anull value
, unfollow the selected author.
A simple HTML UI is used to capture the required information, after which the broadcast operation can be compiled.
- Configure connection Configuration of
dsteem
to communicate with the Steem blockchain - Input variables Collecting the required inputs via an HTML UI
- Get status Get the follow status for the specified author
- Follow operation Execute the
follow
operation
As usual, we have a public/app.js
file which holds the Javascript segment of the tutorial. In the first few lines we define the configured library and packages:
import { Client, PrivateKey } from 'dsteem';
import { Testnet as NetConfig } from '../../configuration'; //A Steem Testnet. Replace 'Testnet' with 'Mainnet' to connect to the main Steem blockchain.
let opts = { ...NetConfig.net };
//connect to a steem node, testnet in this case
const client = new Client(NetConfig.url, opts);
Above, we have dsteem
pointing to the test network with the proper chainId, addressPrefix, and endpoint by importing from the configuration.js
file. Because this tutorial is interactive, we will not publish test content to the main network. Instead, we're using the testnet and a predefined account which is imported once the application loads, to demonstrate following of an author.
window.onload = async () => {
const account = NetConfig.accounts[0];
const accountI = NetConfig.accounts[1];
document.getElementById('username').value = account.address;
document.getElementById('postingKey').value = account.privPosting;
document.getElementById('author').value = accountI.address;
};
The required parameters for the follow operation is recorded via an HTML UI that can be found in the public/index.html
file.
The parameter values are allocated as seen below once the user clicks on the "Follow / Unfollow" button.
window.submitFollow = async () => {
//get private key
const privateKey = dsteem.PrivateKey.fromString(
document.getElementById('postingKey').value
);
//get account name
const follower = document.getElementById('username').value;
//get author permalink
const following = document.getElementById('author').value;
The current follow status for the author is called from the database and a variable is assigned in order to specify whether the follow operation should execute as follow
or unfollow
. For more information on this process you can refer to tutorial 19_get_follower_and_following_list.
console.log({ follower: follower, following: following });
let status = await client.call('follow_api', 'get_following', [
follower,
following,
'blog',
1,
]);
console.log({ status: status });
if (status.length > 0 && status[0].following == following) {
type = '';
} else {
type = 'blog';
}
A JSON with the collected input variables is created in order for the data object
within the broadcast
operation to be completed.
const json = JSON.stringify([
'follow',
{
follower: follower,
following: following,
what: [type], //null value for unfollow, 'blog' for follow
},
]);
The broadcast.json
operation requires a data object
and private key
in order the execute. For the follow/unfollow operation the variables in the object have predefined values. These values can change depending on the type of operation.
const data = {
id: 'follow',
json: json,
required_auths: [],
required_posting_auths: [follower],
};
The broadcast operation is then executed with the created object and the private posting key. We also display the follow status on the UI in order for the user to know the whether the process was a success.
client.broadcast.json(data, privateKey).then(
function(result) {
console.log('user follow result: ', result);
document.getElementById('followResultContainer').style.display = 'flex';
document.getElementById('followResult').className =
'form-control-plaintext alert alert-success';
if (type == 'blog') {
document.getElementById('followResult').innerHTML =
'Author followed';
} else {
document.getElementById('followResult').innerHTML =
'Author unfollowed';
}
},
function(error) {
console.error(error);
document.getElementById('followResultContainer').style.display = 'flex';
document.getElementById('followResult').className =
'form-control-plaintext alert alert-danger';
document.getElementById('followResult').innerHTML = error.jse_shortmsg;
}
);
If either of the values for the user or author does not exist the proper error result will be displayed on the UI. The result is also displayed in the console in order for the user to confirm that a block transaction has taken place. The status of the operation can be verified on the demo account.
- clone this repo
cd tutorials/18_follow_user
npm i
npm run dev-server
ornpm run start
- After a few moments, the server should be running at http://localhost:3000/