0.1.4 • Published 6 years ago

dpayid v0.1.4

Weekly downloads
1
License
MIT
Repository
-
Last release
6 years ago

DPAYID.js

DPayID JavaScript SDK.

Getting started

To install and run DPayID.js, follow this quick start guide

Install

DPayID.js was designed to work both in the browser and in Node.js.

Node.js

To install DPayID.js on Node.js, open your terminal and run:

npm i dpayid --save

Browser

You can create an index.html file and include DPayID.js with:

<script src="https://cdn.jsdelivr.net/npm/dpayid@latest"></script>

SDK Methods

Init SDK

Call the Initialize() method when your app first loads to initialize the SDK:

var dpid = require('dpayid');

var api = dpid.Initialize({
  app: 'social.dapp',
  callbackURL: 'http://localhost:8000/demo/',
  accessToken: 'access_token',
  scope: ['vote', 'comment']
});

Parameters:

  • app: This is the name of the app that was registered in the DPayID V2 dashboard
  • callbackURL: This is the URL that users will be redirected to after interacting with SC2. It must be listed in the "Redirect URI(s)" list in the app settings EXACTLY the same as it is specified here
  • accessToken: If you have an oauth2 access token for this user already you can specify it here, otherwise you can leave it and set it later using dpid.setAccessToken(accessToken).
  • scope: This is a list of operations the app will be able to access on the user's account. For a complete list of scopes see: https://open.benchx.io/dpay/dpayid-js/wiki/OAuth-2#scopes

Get Login URL

The following method returns a URL that you can redirect the user to so that they may log in to your app through SC2:

var link = api.getLoginURL(state);
console.log(link)
// => https://go.dpayid.io/oauth2/authorize?client_id=[app]&redirect_uri=[callbackURL]&scope=vote,comment&state=[state]

Parameters:

  • state: Data that will be passed to the callbackURL for your app after the user has logged in.

After logging in, SC2 will redirect the user to the "redirect_uri" specified in the login url above and add the following query string parameters for your app to use:

  • access_token: This is the oauth2 access token that is required to make any DPay API calls on behalf of the current user. Once you have this you need to tell the SC2 SDK to use it by either specifying it as a parameter to the init() method call or by calling dpid.setAccessToken(accessToken).
  • expires_in: The number of seconds until the access token expires.
  • username: The username of the current user.

Get user profile

Once a user is logged in to your app you can call the following method to get the details of their account:

api.me(function (err, res) {
  console.log(err, res)
});

If it is successful, the result will be a JSON object with the following properties:

{
  account: { id: 338059, name: "jared", ...},
  name: "jared",
  scope: ["vote"],
  user: "jared",
  user_metadata: {},
  _id: "jared"
}

Vote

The vote() method will cast a vote on the specified post or comment from the current user:

api.vote(voter, author, permlink, weight, function (err, res) {
  console.log(err, res)
});

Parameters:

  • voter: The dPay username of the current user.
  • author: The dPay username of the author of the post or comment.
  • permlink: The link to the post or comment on which to vote. This is the portion of the URL after the last "/".
  • weight: The weight of the vote. 10000 equal a 100% vote.
  • callback: A function that is called once the vote is submitted and included in a block. If successful the "res" variable will be a JSON object containing the details of the block and the vote operation.

Comment

The comment() method will post a comment on an existing post or comment from the current user:

api.comment(parentAuthor, parentPermlink, author, permlink, title, body, jsonMetadata, function (err, res) {
  console.log(err, res)
});

The comment() method is rate limited to 5 minutes per root comment (post), and 20 seconds per non-root comment (reply).

Delete Comment

The deleteComment() method will mark a comment as deleted.

api.deleteComment(author, permlink, function (err, res) {
  console.log(err, res)
})

Generate hot signing link

The sign() method creates a URL to which your app can redirect the user to perform a signed transaction on the blockchain such as a transfer or delegation:

var link = api.sign('transfer', {
  to: 'fabien',
  amount: '1.000 BEX',
  memo: 'Hello World!',
}, 'http://localhost:8000/demo/transfer-complete');

console.log(link);
// => https://go.dpayid.io/sign/transfer?to=fabien&amount=1.000%20BEX&memo=Hello%20World!&redirect_uri=http%3A%2F%2Flocalhost%3A8000%2Fdemo%2Ftransfer-complete

Logout

The revokeToken() method will log the current user out of your application by revoking the access token provided to your app for that user:

api.revokeToken(function (err, res) {
  console.log(err, res)
});

Reblog

api.reblog(account, author, permlink, function (err, res) {
  console.log(err, res)
});

Follow

api.follow(follower, following, function (err, res) {
  console.log(err, res)
});

Unfollow

api.unfollow(unfollower, unfollowing, function (err, res) {
  console.log(err, res)
});

Ignore

api.ignore(follower, following, function (err, res) {
  console.log(err, res)
});

Claim Reward Balance

api.claimRewardBalance(account, rewardDPay, rewardBbd, rewardVests, function (err, res) {
  console.log(err, res)
});

Update User Metadata

api.updateUserMetadata(metadata, function (err, res) {
  console.log(err, res)
});
0.1.4

6 years ago

0.1.3

6 years ago

0.1.2

6 years ago

0.1.1

6 years ago