Commit graph

3111 commits

Author SHA1 Message Date
Nathan Hourt
906ffa6351 Fix tests better
The solution being used for initializing the boost test modules is
now deprecated, so update it to use the global test fixture instead
2021-11-11 14:38:36 -05:00
Nathan Hourt
8a6bae6006 Fix tests
These tests did not properly define their BOOST_TEST_MODULE macro,
causing linking to fail in some environments.
2021-11-11 14:35:53 -05:00
Nathan Hourt
0c320fdc71 Add missing header 2021-11-11 14:35:53 -05:00
Nathan Hourt
0d18523d8f Fix dynamic build
In some environments, dynamic linking fails if Boost is static
2021-11-11 14:32:47 -05:00
Nathan Hourt
95afb342c3 Fix to dynamic builds
FC wasn't always getting the memo that it should build dynamically
if Graphene is.
2021-11-11 14:31:47 -05:00
Nathan Hourt
e168d2d830 Fix install of hardfork.hpp 2021-11-11 14:29:34 -05:00
Nathan Hourt
3f50447013 Fix dynamic libs build 2021-11-11 14:29:34 -05:00
Nathan Hourt
c76e1f3157 Toward dynamically reloading contracts...
Add the ability to dynamically unload an auxiliary evaluator (any
evaluator for a given operation type except the first one registered for
that operation type), and as an added convenience, add an idiomatically
consistent way to check if a given index is already registered or not.
2021-11-11 14:27:50 -05:00
Nathan Hourt
082df7ab4a Allow build of dynamic libraries
In order to support dynamically linked nodes based on Graphene, add
support for building dynamic libraries for the core Graphene
modules: chain, db, protocol, net, and utilities.
2021-11-11 14:20:40 -05:00
Nathan Hourt
95d4cbdf4a Add build/IDE artifacts to gitignore 2021-11-11 11:25:47 -05:00
Nathan Hourt
ab113b2fc4 Add support for multiple evaluators per operation type
This commit adds the ability to register multiple evaluator types for a
given operation type. This will be used to allow plug-ins to define their
own evaluators for various operation types (most notably, custom
operations) so that they may be used to carry app-specific data which can
be parsed by a plug-in.
2021-11-11 11:25:47 -05:00
Nathan Hourt
4d836dacb9 Ref !3/#376: Graphene Updates
This adds the most important updates to Graphene from BitShares. Most notably,
https://github.com/bitshares/bitshares-core/issues/1506

Second most notably, it updates Peerplays' FC to be in sync with BitShares FC.

This is a squash commit of several subcommits. The subcommit messages are
reproduced below:

Replace fc::uint128 with boost::multiprecision::uint128_t

replace smart_ref with shared_ptr

Fixes/Remove Unused

Remove NTP time

Remove old macro

This macro is now in FC, so no need to define it here anymore

Replaced fc::array with std::array

Separate exception declaration and implementation

Adapted to fc promise changes

Fixes

Add back in some of Peter's fixes that got lost in the cherry pick

_hash endianness fixes

Remove all uses of fc/smart_ref

It's gone, can't use it anymore

Replace improper static_variant operator overloads with comparators

Fixes

Remove boost::signals from build system; it's header-only so it's not
listed in cmake anymore.

Also remove some unused hashing code

Impl. pack/unpack functions for extension class

Ref #1506: Isolate chain/protocol to its own library

Ref #1506: Add object_downcast_t

Allows the more concise expression `object_downcast_t<xyz>` instead of
the old `typename object_downcast<xyz>::type`

Ref #1506: Move ID types from db to protocol

The ID types, object_id and object_id_type, were defined in the db
library, and the protocol library depends on db to get these types.
Technically, the ID types are defined by the protocol and used by the
database, and not vice versa. Therefore these types should be in the
protocol library, and db should depend on protocol to get them.

This commit makes it so.

Ref #1506: Isolate chain/protocol to its own library

Remove commented-out index code

Wrap overlength line

Remove unused key types

Probably fix Docker build

Fix build after rebase

Ref #1506/#1737: Some requested changes

Ref #1506/#1737: Macro-fy ID type definitions

Define macros to fully de-boilerplate ID type definitions.

Externalities:
 - Rename transaction_object -> transaction_history_object
 - Rename impl_asset_dynamic_data_type ->
impl_asset_dynamic_data_object_type
 - Rename impl_asset_bitasset_data_type ->
impl_asset_bitasset_data_object_type

The first is to avoid a naming collision on transaction_id_type, and the
other two are to maintain consistency with the naming of the other
types.

Ref #1506/#1737: Fix clean_name()

Ref #1506/#1737: Oops

Fix .gitignore

Externalized serialization in protocol library

Fix compile sets

Delete a couple of ghost files that were in the tree but not part
of the project (I accidentally added them to CMakeLists while
merging, but they're broken and not part of the Peerplays code), and
add several files that got dropped from the build during merge.

General fixes

Fix warnings, build issues, unused code, etc.

Fix #1772 by decprecating cli_wallet -H

More fixes

Fix errors and warnings and generally coax it to build

Fix test

I'm pretty sure this didn't break from what I did... But I can't build
the original code, so I can't tell. Anyways, this one now passes...
Others still fail...

Small fix

Fix crash in auth checks

Final fixes

Last round of fixes following the rebase to Beatrice

Rename project in CMakeLists.txt

The CMakeLists.txt declared this project as BitShares and not Peerplays,
which makes it confusing in IDEs. Rename it to be clear which project is
open.

Resolve #374

Replace all object refs in macros with IDs, and fix affected tests to look
up objects by ID rather than using invalidated refs.

A full audit of all tests should be performed to eliminate any further
usage of invalidated object references.

Resolve #373: Add object notifiers

Various fixes

Fixes to various issues, primarily reflections, that cropped up
during merge conflict resolution

Fix startup bug in Bookie plugin

Bookie plugin was preventing the node from starting up because it
registered its secondary indexes to create objects in its own primary
indexes to track objects being created in other primary indexes, and did
so during its `initialize()` step, which is to say, before the database
was loaded from disk at startup. This caused the secondary indexes to
create tracker objects when the observed indexes were loading objects
from disk. This then caused a failure when these tracker indexes were
later loaded from disk, and the first object IDs collided.

This is fixed by refraining from defining secondary indexes until the
`startup()` stage rather than the `initialize()` stage. Primary indexes
are registered in `initialize()`, secondary indexes are registered in
`startup()`.

This also involved adding a new method, "add_secondary_index()", to
`object_database`, as before there was no way to do this because you
couldn't get a non-const index from a non-const database.

I have no idea how this was working before I got here...

Fix egenesis install

Fixes after updates

Rebase on updated develop branch and fix conflicts
2021-11-11 11:25:47 -05:00
Michel Santos
111ac16e92 Merge branch master into graphene-updates 2021-11-09 16:24:26 -05:00
ss
8e5dfb0e72 Merge branch 'beatrice' into develop 2021-09-11 01:50:55 +02:00
ss
01f860e15b Merge branch 'master' into beatrice 2021-09-11 01:49:05 +02:00
Bobinson K B
2778a99842 Merge branch 'hotfix/son-cli-test-fix' into 'master'
Fix failing son cli test

See merge request PBSA/peerplays!26
2021-07-27 12:47:05 +00:00
sierra19XX
d75177b7a1 fix cli test 2021-07-27 09:38:51 +00:00
Bobinson K B
6035d29428 Merge branch 'feature/rel-mainnet-jul21' into 'master'
Merge Beatrice changes to Main net

See merge request PBSA/peerplays!25
2021-07-26 20:16:25 +00:00
sierra19XX
ba69da5d5c Merge Beatrice changes to Main net 2021-07-26 20:16:24 +00:00
Bobinson K B
183906370b Merge branch 'feature/reserve-tokens' into 'develop'
Reserve popular tokens

See merge request PBSA/peerplays!24
2021-06-29 11:24:08 +00:00
sierra19XX
8b84459e8c Reserve popular tokens 2021-06-29 11:24:07 +00:00
Bobinson K B
5dc753054b Merge branch 'feature/beatrice-changes-to-develop' into 'develop'
merge beatrice release delta changes into develop

See merge request PBSA/peerplays!23
2021-06-18 09:09:02 +00:00
sierra19XX
e6b57a2285 merge beatrice release delta changes into develop 2021-06-15 11:51:57 +00:00
Bobinson K B
5ae230e533 Merge branch 'feature/testnet-release-jun2021' into 'beatrice'
Testnet Beatrice release June 2021

See merge request PBSA/peerplays!22
2021-06-05 22:22:45 +00:00
sierra19XX
0a5e3d7080 Testnet Beatrice release June 2021 2021-06-05 22:22:45 +00:00
Bobinson K B
20c9e0f9a3 Merge branch 'feature/son-wrong-weights' into 'develop'
fix wrong son weights from voting

See merge request PBSA/peerplays!20
2021-05-26 16:08:43 +00:00
Bobinson K B
6c8aed3c18 Merge branch 'feature/add-cliwallet-version' into 'develop'
add cli wallet version

See merge request PBSA/peerplays!21
2021-05-25 12:26:13 +00:00
sierra19XX
557270db39 add cli wallet version 2021-05-21 14:27:03 +00:00
sierra19XX
93c980ab2c fix wrong son weights from voting 2021-05-18 12:05:44 +00:00
Bobinson K B
7eba0eb2a8 Merge branch 'support/sonarcloud' into 'develop'
Update .sonarcloud.properties

See merge request PBSA/peerplays!19
2021-05-15 03:46:35 +00:00
Roshan Syed
d8246bc404 chore: update .sonarcloud.properties 2021-05-14 19:59:42 +00:00
Bobinson K B
ec464694a4 Merge branch 'feature/add-get-blocks' into 'develop'
Feature/add get blocks

See merge request PBSA/peerplays!18
2021-05-14 07:54:43 +00:00
sierra19XX
997941611c add ddos mitigation 2021-05-12 13:28:10 +00:00
sierra19XX
b22086ff7e add get_blocks 2021-05-12 11:44:27 +00:00
Bobinson K B
8b3952d26b Merge branch 'feature/sidechain-throttling' into 'develop'
Rate limiting for son deposit, withdrawal, pw change, tx settle operations

See merge request PBSA/peerplays!17
2021-05-03 11:15:43 +00:00
sierra19XX
668f677867 rate limiting for son deposit, withdrawal, pw change, tx settle operations 2021-05-03 09:26:43 +00:00
Bobinson K B
cd0bcf3087 Delete codeql-analysis.yml 2021-03-31 17:29:14 +00:00
Bobinson K B
010b873c8e
Create codeql-analysis.yml 2021-03-31 22:05:16 +05:30
Roshan Syed
2c396f6b19
ci: added automated docker image building and upload (#413) 2021-03-31 17:59:27 +05:30
Bobinson K B
0b0718f739 Merge branch 'issue/dex-crash' into 'develop'
dex crash fix - replace assert with FC_ASSERT

See merge request PBSA/peerplays!15
2021-03-30 11:58:48 +00:00
sierra19XX
974c8f987e dex crash fix - replace assert with FC_ASSERT 2021-03-29 22:52:48 +00:00
Bobinson K B
652d37e206 Merge branch 'feature/hf-btc-flags-change' into 'develop'
Feature/hf btc flags change

See merge request PBSA/peerplays!14
2021-03-22 12:13:09 +00:00
sierra19XX
30e4b50891 only modify flag if it is not already 2021-03-19 12:00:01 +00:00
sierra19XX
ad5f89ba99 change the asset flags to allow transfers/dex trades of pBTC 2021-03-17 12:48:24 +00:00
serkixenos
ae712122d4 Merge branch 'hotfix/build-warnings-210210' into 'develop'
Remove build warnings & update Doxygen file

See merge request PBSA/peerplays!12
2021-02-22 13:29:03 +00:00
serkixenos
2a977793de Remove build warnings & update Doxygen file 2021-02-10 12:53:51 +01:00
serkixenos
d3a3722c1e Merge branch 'master' into beatrice 2021-02-09 13:13:21 +01:00
Bobinson K B
bb4fc3c9c1 Merge branch 'hotfix/master-son-vb-checks' into 'master'
Check vesting balance properties before creating/updating SON

See merge request PBSA/peerplays!11
2021-02-09 03:43:42 +00:00
serkixenos
b362ca23a6 Check vesting balance properties before creating/updating SON 2021-02-09 03:43:42 +00:00
serkixenos
4b0d7d4700 Merge branch 'develop' into 'beatrice'
Merge develop to beatrice

See merge request PBSA/peerplays!10
2021-01-28 20:19:02 +00:00