<center></center> My goal for this release was to significantly simplify handling of blockchain event streams by extracting custom ops into their own structs, parsing values out of strings and adding block metadata. As one example, you can now pattern match against reblog or follows. Structured ops event producer follows [GenStage](http://elixir-lang.org/blog/2016/07/14/announcing-genstage/) spec which allows you to easily patch into the transformation pipeline at any step: block producer, ops producer or structured ops producer. # Repos and docs * [github](https://github.com/cyberpunk-ventures/steemex) * [hex.pm](https://hex.pm/packages/steemex) * [docs](https://hexdocs.pm/steemex) # Changelog * added `Steemex.Stage.StructuredOps.ProducerConsumer` module * To susbcribe use the following GenStage option: `subscribe_to: Steemex.Stage.StructuredOps.ProducerConsumer`. All producers use BroadcastDispatcher -- blockchain event wills be sent to all subscribed consumers. * added multiple structured ops structs * added multiple transformation functions and tests for each * event shape of structured ops producer has changed to `{op_data, op_metadata}` where op_data can be matched against ops structs * event shape of ops producer has been changed to `{op_type, op_data, op_metadata}` * transfer value strings are now parsed into operation struct fields * tags, app fields are added to structured comment struct * op_metadata is now available with `%{height: h, timestamp: t}` fields * updated supervisor module for GenStage producers * updated example of GenStage consumer for structured steem operation with pattern matching on structs and metadata ## A GenStage consumer example ``` defmodule Steemex.StructuredStage.Ops.ExampleConsumer do use GenStage alias Steemex.StructuredOps require Logger def start_link(args, options \\ []) do GenStage.start_link(__MODULE__, args, options) end def init(state) do {:consumer, state, subscribe_to: state[:subscribe_to]} end def handle_events(events, _from, state) do for op <- events do process_event(op) end {:noreply, [], state} end def process_event({%StructuredOps.Reblog{} = op_data, %{height: h, timestamp: t} = op_metadata}) do Logger.info """ New reblog: #{inspect op_data} at height #{h} and time #{t} """ end def process_event({op_data, %{height: h, timestamp: t} = op_metadata}) do Logger.info """ New operation: #{inspect op_data} at height #{h} and time #{t} """ end end ``` # Roadmap * Add latest blockchain ops * Add more structured ops and transformations * Add transaction broadcast # About Elixir Elixir is a functional programming language with superior concurrency primitives, distributed computation and fault tolerance capabilities based on Erlang/OTP. Personally, I am really happy with my bet on Elixir to build cryptotokens related apps and strongly recommend every developer to try it. Learning resources: * [ElixirConf Jose Valim Keynote](http://confreaks.tv/videos/elixirconf2016-keynote) * [ElixirConf 2016 Chris McCord Keynote](http://confreaks.tv/videos/elixirconf2016-keynote) * [Elixir School](https://elixirschool.com/) * [Elixir Crash Course](http://elixir-lang.org/crash-course.html) <center>(∩^o^)⊃━☆゜.*</center>
author | ontofractal |
---|---|
permlink | steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem |
category | steemdev |
json_metadata | {"tags":["steemdev","steem","open-source","steemstem","steem-dev"],"image":["http://i.imgur.com/QKOa4iu.png"],"links":["http://elixir-lang.org/blog/2016/07/14/announcing-genstage/","https://github.com/cyberpunk-ventures/steemex","https://hex.pm/packages/steemex","https://hexdocs.pm/steemex","http://confreaks.tv/videos/elixirconf2016-keynote","https://elixirschool.com/","http://elixir-lang.org/crash-course.html"],"app":"steemit/0.1","format":"markdown"} |
created | 2017-06-07 19:14:54 |
last_update | 2017-06-08 08:18:03 |
depth | 0 |
children | 5 |
last_payout | 2017-06-14 19:14:54 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 452.820 HBD |
curator_payout_value | 115.567 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 3,365 |
author_reputation | 61,670,850,962,884 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 4,355,901 |
net_rshares | 23,815,255,385,791 |
author_curate_reward | "" |
voter | weight | wgt% | rshares | pct | time |
---|---|---|---|---|---|
fminerten | 0 | 363,232,090,910 | 25% | ||
fmooo | 0 | 31,940,253,808 | 25% | ||
steempty | 0 | 297,064,820,417 | 25% | ||
rossco99 | 0 | 800,658,566,772 | 100% | ||
boy | 0 | 4,518,154,882 | 100% | ||
bue-witness | 0 | 5,509,126,870 | 100% | ||
bunny | 0 | 780,897,113 | 100% | ||
bue | 0 | 91,830,122,932 | 100% | ||
mini | 0 | 2,414,878,793 | 100% | ||
moon | 0 | 307,035,494 | 100% | ||
boatymcboatface | 0 | 594,722,796,741 | 100% | ||
healthcare | 0 | 899,951,822 | 100% | ||
daniel.pan | 0 | 1,423,744,883 | 100% | ||
donkeypong | 0 | 976,779,001,891 | 100% | ||
helen.tan | 0 | 411,592,199 | 100% | ||
kingscrown | 0 | 3,147,426,803,146 | 100% | ||
hipster | 0 | 424,720,223,603 | 96% | ||
pal | 0 | 367,286,770,314 | 100% | ||
blakemiles84 | 0 | 124,831,499,603 | 100% | ||
theshell | 0 | 89,167,538,317 | 100% | ||
cm-steem | 0 | 117,230,752,780 | 100% | ||
rok-sivante | 0 | 417,514,607,234 | 100% | ||
ratel | 0 | 1,415,302,982 | 65% | ||
tensorflow | 0 | 16,288,601,055 | 100% | ||
raphaelom | 0 | 1,076,948,949 | 100% | ||
christoryan | 0 | 0 | 1% | ||
geoffrey | 0 | 273,839,604,666 | 100% | ||
pmartynov | 0 | 184,704,322,362 | 100% | ||
robrigo | 0 | 91,211,019,825 | 100% | ||
ausbitbank | 0 | 1,763,806,637,367 | 50% | ||
freeyourmind | 0 | 763,619,820,504 | 100% | ||
jesta | 0 | 294,851,436,612 | 100% | ||
biophil | 0 | 22,140,184,371 | 100% | ||
speda | 0 | 68,966,517,133 | 100% | ||
igster | 0 | 28,103,551,197 | 100% | ||
transisto | 0 | 3,822,960,277,419 | 95% | ||
mapipaz | 0 | 429,594,578 | 100% | ||
streetstyle | 0 | 127,404,257,271 | 100% | ||
inertia | 0 | 292,915,663,497 | 100% | ||
alsprinting | 0 | 2,687,693,945 | 100% | ||
sergey44 | 0 | 134,333,290 | 100% | ||
marius19 | 0 | 38,460,870,630 | 100% | ||
ace108 | 0 | 129,167,166,551 | 30% | ||
craigslist | 0 | 608,950,228 | 100% | ||
dez1337 | 0 | 14,579,682,874 | 100% | ||
letc | 0 | 1,374,786,935 | 50% | ||
andrew0 | 0 | 3,545,129,273 | 100% | ||
shanejonas | 0 | 63,314,528 | 100% | ||
snowflake | 0 | 784,443,979,682 | 100% | ||
jrcornel | 0 | 591,623,554,125 | 100% | ||
inv | 0 | 414,605,094,704 | 25% | ||
fooblic | 0 | 5,010,678,895 | 99% | ||
bledarus | 0 | 550,552,647 | 100% | ||
sc-steemit | 0 | 2,308,464,613 | 100% | ||
stylo | 0 | 2,131,561,038 | 100% | ||
philipnbrown | 0 | 1,066,535,727 | 100% | ||
neptun | 0 | 3,355,413,246 | 100% | ||
samstonehill | 0 | 15,776,587,238 | 30% | ||
mada | 0 | 27,203,711,206 | 100% | ||
julianita | 0 | 2,205,328,146,605 | 97% | ||
jimmco | 0 | 29,792,439,685 | 100% | ||
ontofractal | 0 | 24,720,666,801 | 100% | ||
etcmike | 0 | 286,476,892,276 | 100% | ||
barrydutton | 0 | 118,649,810,818 | 100% | ||
sharingeverybite | 0 | 14,946,922,655 | 100% | ||
crowe | 0 | 59,940,129 | 100% | ||
sammie | 0 | 979,064,322 | 100% | ||
shenanigator | 0 | 21,206,293,478 | 100% | ||
penguinpablo | 0 | 110,030,334,401 | 47% | ||
annamalocaris | 0 | 64,508,225 | 100% | ||
aggroed | 0 | 6,520,516,562 | 15% | ||
the-ego-is-you | 0 | 7,334,711,449 | 100% | ||
heroic15397 | 0 | 9,851,053,169 | 100% | ||
dodders007 | 0 | 15,060,039,274 | 100% | ||
bosjaya | 0 | 179,949,347 | 100% | ||
goldmatters | 0 | 163,178,759,211 | 100% | ||
brimax | 0 | 12,433,735,906 | 100% | ||
slider2990 | 0 | 35,815,441,856 | 100% | ||
tomino | 0 | 2,413,954,821 | 100% | ||
stray | 0 | 8,758,430,743 | 100% | ||
steemstem | 0 | 206,152,876,621 | 33% | ||
ebryans | 0 | 19,927,768,324 | 50% | ||
joshuaatiemo | 0 | 263,138,939 | 100% | ||
jmehta | 0 | 704,505,944 | 100% | ||
angel76 | 0 | 8,473,198,909 | 100% | ||
crowdfundedwhale | 0 | 34,406,968,172 | 60% | ||
miki1 | 0 | 1,600,495,952 | 100% | ||
writingamigo | 0 | 5,607,031,460 | 100% | ||
vitality | 0 | 16,746,154,370 | 100% | ||
soushi888 | 0 | 9,995,889,361 | 100% | ||
tamersameeh | 0 | 251,738,415 | 100% | ||
someonewhoisme | 0 | 723,064,229,638 | 100% | ||
automaton | 0 | 989,962,604 | 100% | ||
raja | 0 | 153,135,998 | 100% | ||
wattacut | 0 | 320,535,116 | 100% | ||
aaronmda | 0 | 442,783,105 | 100% | ||
anwarabdullah | 0 | 166,156,293 | 100% | ||
bookman | 0 | 4,025,377,901 | 100% | ||
comfortgenius | 0 | 396,069,005 | 100% | ||
vikx | 0 | 364,222,370 | 100% | ||
leviarcoin | 0 | 1,079,371,187 | 50% | ||
thomasgutierrez | 0 | 3,025,705,346 | 100% | ||
kwak | 0 | 33,607,523,518 | 100% | ||
zerometal | 0 | 1,195,464,897 | 100% | ||
elevator09 | 0 | 192,335,491 | 100% | ||
mckenzie259 | 0 | 0 | 100% | ||
aismor | 0 | 545,082,061 | 100% | ||
prameshtyagi | 0 | 2,698,513,150 | 7% | ||
velimir | 0 | 346,555,404 | 10% | ||
blackvapor | 0 | 2,029,967,548 | 100% | ||
kalamur | 0 | 3,068,508,663 | 100% | ||
uvas | 0 | 1,198,632,586 | 100% | ||
graveric60 | 0 | 1,027,270,803 | 100% | ||
alex13 | 0 | 1,218,844,876 | 100% | ||
danishmmir | 0 | 1,461,920,305 | 100% | ||
grognak | 0 | 204,571,952,599 | 100% | ||
kwahzee | 0 | 191,951,978 | 100% | ||
mandagoi | 0 | 7,372,155,446 | 50% | ||
lautenglye | 0 | 674,378,217 | 100% | ||
jasonb1 | 0 | 1,338,785,168 | 100% | ||
emilniz | 0 | 354,791,140 | 100% | ||
callihappiness | 0 | 9,676,633,130 | 100% | ||
ijoel | 0 | 934,632,424 | 100% | ||
youknow212012 | 0 | 1,713,981,736 | 100% | ||
budimir | 0 | 230,266,817 | 100% | ||
recrypto | 0 | 2,564,568,329 | 100% | ||
grimboslice819 | 0 | 8,094,699,186 | 100% | ||
nirmal | 0 | 756,430,507 | 100% | ||
orinklev | 0 | 424,188,239 | 100% | ||
freshstuff | 0 | 75,642,990 | 100% | ||
silverfortune | 0 | 618,634,653 | 100% | ||
zack813 | 0 | 302,571,921 | 100% | ||
faurman | 0 | 438,729,264 | 100% | ||
hangeul | 0 | 121,028,752 | 100% | ||
styxer | 0 | 680,786,732 | 100% | ||
hackersploit | 0 | 741,301,036 | 100% | ||
minnyfatty | 0 | 302,571,813 | 40% | ||
aloha-mylife | 0 | 695,914,906 | 100% | ||
crypto-p | 0 | 166,526,919,620 | 100% | ||
basmamoughal | 0 | 121,875,061 | 100% | ||
ocean-waffles | 0 | 284,374,955 | 100% | ||
randowhale | 0 | 1,591,793,041,420 | 78% | ||
tabris | 0 | 0 | 100% | ||
indygamer | 0 | 0 | 100% | ||
moddet | 0 | 0 | 100% | ||
randolphpark | 0 | 0 | 100% |
yours is very benefits to me
author | ijoel |
---|---|
permlink | re-ontofractal-steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem-20170612t121424224z |
category | steemdev |
json_metadata | {"tags":["steemdev"],"app":"steemit/0.1"} |
created | 2017-06-12 12:14:33 |
last_update | 2017-06-12 12:14:33 |
depth | 1 |
children | 0 |
last_payout | 2017-06-19 12:14:33 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 0.000 HBD |
curator_payout_value | 0.000 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 28 |
author_reputation | 12,761,279,731,286 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 4,653,958 |
net_rshares | 0 |
Do what?
author | leviathanfisher |
---|---|
permlink | re-ontofractal-steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem-20180830t083621261z |
category | steemdev |
json_metadata | {"tags":["steemdev"],"app":"steemit/0.1"} |
created | 2018-08-30 08:36:21 |
last_update | 2018-08-30 08:36:21 |
depth | 1 |
children | 0 |
last_payout | 2018-09-06 08:36:21 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 0.000 HBD |
curator_payout_value | 0.000 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 8 |
author_reputation | 164,296,470,172 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 69,776,789 |
net_rshares | 0 |
Seems Good :)
author | nirmal |
---|---|
permlink | re-ontofractal-steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem-20170607t202111212z |
category | steemdev |
json_metadata | {"tags":["steemdev"],"app":"steemit/0.1"} |
created | 2017-06-07 20:21:12 |
last_update | 2017-06-07 20:21:12 |
depth | 1 |
children | 0 |
last_payout | 2017-06-14 20:21:12 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 0.000 HBD |
curator_payout_value | 0.000 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 13 |
author_reputation | 1,065,719,594,079 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 4,359,315 |
net_rshares | 360,898,972 |
author_curate_reward | "" |
voter | weight | wgt% | rshares | pct | time |
---|---|---|---|---|---|
funcore | 0 | 360,898,972 | 100% |
This post received a 78% upvote from @randowhale thanks to @jesta! For more information on @randowhale [click here](https://steemit.com/steemit/@randowhale/introducing-randowhale-will-you-get-the-100-vote-give-it-a-shot)!
author | randowhale |
---|---|
permlink | re-steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem-20170608t054350 |
category | steemdev |
json_metadata | "{"format": "markdown", "app": "randowhale/0.1"}" |
created | 2017-06-08 05:43:51 |
last_update | 2017-06-08 05:43:51 |
depth | 1 |
children | 0 |
last_payout | 2017-06-15 05:43:51 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 0.000 HBD |
curator_payout_value | 0.000 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 222 |
author_reputation | 47,657,457,485,459 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 4,384,103 |
net_rshares | 0 |
Hello, I'm interested in elixir language, can you please tag posts related to elixir? Also, I wonder what environment do you use to write code/test program in elixir?
author | tensorflow |
---|---|
permlink | re-ontofractal-steemex-v0-11-released-now-with-producer-of-structured-operations-open-source-elixir-library-for-steem-20170610t174201037z |
category | steemdev |
json_metadata | {"tags":["steemdev"],"app":"steemit/0.1"} |
created | 2017-06-10 17:42:00 |
last_update | 2017-06-10 17:42:00 |
depth | 1 |
children | 0 |
last_payout | 2017-06-17 17:42:00 |
cashout_time | 1969-12-31 23:59:59 |
total_payout_value | 0.000 HBD |
curator_payout_value | 0.000 HBD |
pending_payout_value | 0.000 HBD |
promoted | 0.000 HBD |
body_length | 168 |
author_reputation | 1,359,801,546,368 |
root_title | "Steemex v0.11 released: now with producer of structured operations [open source Elixir library for Steem]" |
beneficiaries | [] |
max_accepted_payout | 1,000,000.000 HBD |
percent_hbd | 10,000 |
post_id | 4,543,649 |
net_rshares | 0 |