Skip to content
Snippets Groups Projects
Commit 835731fb authored by inertia's avatar inertia
Browse files

all about condenser

parent 21b47939
No related branches found
No related tags found
3 merge requests!27More HIVE References Fix Released,!23Production deploy for remaining top-level references,!20all about condenser
--- ---
title: Steemit.com title: hive.blog
position: 1 position: 1
--- ---
#### steemit.com endpoints #### steemit.com endpoints
Steemit.com offers a few endpoints for getting common data. User profile and post JSON data is very convenient and simple by appending .json Hive.blog offers a few endpoints for getting common data. User profile and post JSON data is very convenient and simple by appending .json
to your request. to your request.
Getting a particular user profile JSON: Getting a particular user profile JSON:
``` ```
https://steemit.com/@curie.json https://hive.blog/@curie.json
``` ```
User object User object
...@@ -112,51 +112,76 @@ User object ...@@ -112,51 +112,76 @@ User object
Getting a particular post JSON: Getting a particular post JSON:
``` ```
https://steemit.com/curation/@curie/the-daily-curie-12-13-feb-2017.json https://hive.blog/curation/@curie/the-daily-curie-12-13-feb-2017.json
``` ```
Post object Post object
```json ```json
{ {
"post":{ "post": {
"id":1720643, "id": 1965592,
"author":"curie", "author": "curie",
"permlink":"the-daily-curie-08-09-jan-2017", "permlink": "the-daily-curie-12-13-feb-2017",
"category":"curation", "category": "curation",
"parent_author":"", "parent_author": "",
"parent_permlink":"curation", "parent_permlink": "curation",
"title":"The Daily Curie (08-09 Jan 2017)", "title": "The Daily Curie (12-13 Feb 2017)",
"body":"<center>https://s29.postimg.org/dgtsfe7if/curie2.png</center>\n## Introduction\n[Curie](https://steemit.com/steemit/@donkeypong/announcing-project-curie-bringing-rewards-and-recognition-to-steemit-s-undiscovered-and-emerging-authors) is a commu ...", "body": "...",
"last_update":"2017-01-09T12:20:15", "json_metadata": {
"created":"2017-01-09T12:20:15", "tags": ["curation", "curie"],
"active":"2017-01-11T22:44:57", "users": [
"last_payout":"2017-02-09T14:40:54", "nextgencrypto",
"depth":0, "berniesanders",
"children":36, "val",
"children_rshares2":"0", "silversteem",
"net_rshares":0, "clayop",
"abs_rshares":0, "hendrikdegrote",
"vote_rshares":0, "proskynneo",
"children_abs_rshares":0, "kushed",
"cashout_time":"1969-12-31T23:59:59", "curie"
"max_cashout_time":"1969-12-31T23:59:59", ],
"total_vote_weight":0, "image": [],
"reward_weight":10000, "links": [],
"total_payout_value":"0.000 SBD", "app": "steemit/0.1",
"curator_payout_value":"0.000 SBD", "format": "markdown"
"author_rewards":0, },
"net_votes":519, "last_update": "2017-02-13T18:00:51",
"root_comment":1720643, "created": "2017-02-13T18:00:51",
"mode":"archived", "active": "2017-02-14T16:19:24",
"max_accepted_payout":"0.000 SBD", "last_payout": "2017-03-16T19:08:27",
"percent_steem_dollars":10000, "depth": 0,
"allow_replies":true, "children": 9,
"allow_votes":true, "net_rshares": 0,
"allow_curation_rewards":true, "abs_rshares": 0,
"url":"/curation/@curie/the-daily-curie-08-09-jan-2017", "vote_rshares": 0,
"root_title":"The Daily Curie (08-09 Jan 2017)", "children_abs_rshares": 0,
"pending_payout_value":"0.000 SBD", "cashout_time": "1969-12-31T23:59:59",
"total_pending_payout_value":"0.000 SBD" "max_cashout_time": "1969-12-31T23:59:59",
} "total_vote_weight": 0,
"reward_weight": 10000,
"total_payout_value": "23.678 HBD",
"curator_payout_value": "1.196 HBD",
"author_rewards": 167726,
"net_votes": 465,
"root_author": "curie",
"root_permlink": "the-daily-curie-12-13-feb-2017",
"max_accepted_payout": "1000000.000 HBD",
"percent_steem_dollars": 0,
"allow_replies": true,
"allow_votes": true,
"allow_curation_rewards": true,
"beneficiaries": [],
"url": "/curation/@curie/the-daily-curie-12-13-feb-2017",
"root_title": "The Daily Curie (12-13 Feb 2017)",
"pending_payout_value": "0.000 HBD",
"total_pending_payout_value": "0.000 HBD",
"active_votes": [],
"replies": [],
"author_reputation": "545477526857484",
"promoted": "0.000 HBD",
"body_length": 0,
"reblogged_by": []
},
"status": "200"
} }
``` ```
...@@ -4,15 +4,15 @@ position: 4 ...@@ -4,15 +4,15 @@ position: 4
--- ---
# Definition # Definition
Imagehoster is a Steem-powered image hosting and proxying service. Any image uploaded to, or proxied through, your Imagehoster has a copy stored within it. This means that the image continues to be available even if 3rd party sites go down or change their URLs. For as long as your instance of imagehoster is running the image will be available, anytime you need it. Imagehoster is a Hive-powered image hosting and proxying service. Any image uploaded to, or proxied through, your Imagehoster has a copy stored within it. This means that the image continues to be available even if 3rd party sites go down or change their URLs. For as long as your instance of imagehoster is running the image will be available, anytime you need it.
The purpose of this tool is to provide a way to host and proxy images used by [condenser](https://github.com/steemit/condenser#condenser) to help maintain the privacy of the authors and general users accessing the images. The purpose of this tool is to provide a way to host and proxy images used by [condenser](https://gitlab.syncad.com/hive/condenser#condenser) to help maintain the privacy of the authors and general users accessing the images.
Using ImageHoster will help limit access to IP addresses of the general user. It will also strip [image metadata](https://en.wikipedia.org/wiki/Exif) related to the author's geographical location. It also helps to verify that the original author uploaded the image they intended. Using ImageHoster will help limit access to IP addresses of the general user. It will also strip [image metadata](https://en.wikipedia.org/wiki/Exif) related to the author's geographical location. It also helps to verify that the original author uploaded the image they intended.
The ability to upload images on steemit.com was originally added in January, 2017. Please note that this tool **does not** store any image data on the blockchain. The ability to upload images on steemit.com was originally added in January, 2017. Please note that this tool **does not** store any image data on the blockchain.
Detaied information on Imagehoster can be found in its [repository](https://github.com/steemit/imagehoster/blob/master/README.md) Detaied information on Imagehoster can be found in its [repository](https://gitlab.syncad.com/hive/imagehoster/-/blob/master/README.md#imagehoster)
## The API ## The API
...@@ -37,7 +37,7 @@ This returns a JSON object container the URL to the uploaded image, ex: ...@@ -37,7 +37,7 @@ This returns a JSON object container the URL to the uploaded image, ex:
} }
``` ```
For this to succeed it requires a signature from a Steem account in good standing. For this to succeed it requires a signature from a Hive account in good standing.
#### 2. Fetch an uploaded image <a name="fetch-upload"></a> #### 2. Fetch an uploaded image <a name="fetch-upload"></a>
...@@ -70,12 +70,12 @@ The avatars follow the same sizing rules as proxied images, so you not guarantee ...@@ -70,12 +70,12 @@ The avatars follow the same sizing rules as proxied images, so you not guarantee
#### 5. Signing uploads <a name="signing"></a> #### 5. Signing uploads <a name="signing"></a>
Uploads also require a signature made by a Steem account's posting authority. The account has to also be above a certain (service configurable) reputation threshold. Uploads also require a signature made by a Hive account's posting authority. The account has to also be above a certain (service configurable) reputation threshold.
Creating a signature for `node.js` and with `dsteem`: Creating a signature for `node.js` and with `dhive`:
```javascript ```javascript
const dsteem = require('dsteem') const dhive = require('dhive')
const crypto = require('crypto') const crypto = require('crypto')
const fs = require('fs') const fs = require('fs')
...@@ -87,7 +87,7 @@ if (!wif || !file) { ...@@ -87,7 +87,7 @@ if (!wif || !file) {
} }
const data = fs.readFileSync(file) const data = fs.readFileSync(file)
const key = dsteem.PrivateKey.fromString(wif) const key = dhive.PrivateKey.fromString(wif)
const imageHash = crypto.createHash('sha256') const imageHash = crypto.createHash('sha256')
.update('ImageSigningChallenge') .update('ImageSigningChallenge')
.update(data) .update(data)
...@@ -101,7 +101,7 @@ process.stdout.write(key.sign(imageHash).toString() + '\n') ...@@ -101,7 +101,7 @@ process.stdout.write(key.sign(imageHash).toString() + '\n')
This imagehoster demo must be run through linux due to a dependency on the `make` commandline. This imagehoster demo must be run through linux due to a dependency on the `make` commandline.
You will also require `node.js` and `yarn` to run You will also require `node.js` and `yarn` to run
* git clone https://github.com/steemit/imagehoster * git clone https://gitlab.syncad.com/hive/imagehoster
* Run `make devserver` * Run `make devserver`
......
images/honey-comb-icon.png

74.5 KiB

...@@ -73,7 +73,7 @@ spam on a blockchain, like everything else on a blockchain, is forever. Eww. ...@@ -73,7 +73,7 @@ spam on a blockchain, like everything else on a blockchain, is forever. Eww.
So for those tutorials we use a [testnet](https://testnet.steem.vc/) setup and maintained by user So for those tutorials we use a [testnet](https://testnet.steem.vc/) setup and maintained by user
[@almost-digital](https://steemit.com/@almost-digital). You can see its current status, and learn how to easily create [@almost-digital](https://steemit.com/@almost-digital). You can see its current status, and learn how to easily create
accounts and connect to it at [https://testnet.steem.vc/](https://testnet.steem.vc/). And depending on the day, you can accounts and connect to it at [https://testnet.steem.vc/](https://testnet.steem.vc/). And depending on the day, you can
even use an outdated version of [condenser](https://github.com/steemit/condenser) to crawl it at even use an outdated version of [condenser](https://gitlab.syncad.com/hive/condenser#condenser) to crawl it at
[https://condenser.steem.vc/](https://condenser.steem.vc/) [https://condenser.steem.vc/](https://condenser.steem.vc/)
Credentials for demo accounts on the testnet are in [tutorials/configuration.js](tutorials/configuration.js)`. Credentials for demo accounts on the testnet are in [tutorials/configuration.js](tutorials/configuration.js)`.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment