Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: modify stop #32

Merged
merged 10 commits into from
Aug 5, 2023
Merged

feat: modify stop #32

merged 10 commits into from
Aug 5, 2023

Conversation

matiasvillaverde
Copy link
Owner

  • feat: Add functionality to modify stop loss orders in CLI
  • feat: Update trade stop modification functionality
  • Restructure trade-related validators and actions
  • feat: modify stop interface
  • feat: Refactor order updating methods and update trade handling logic
  • feat: Modify stop order implementation to include account parameter
  • fix: Refactor trade modification functionality
  • feat: Add trade validation and trade action functionality
  • test: Add new test case and implementation for modifying stop price in a long trade
  • feat: Refactor order creation and modification functions

- Add functionality to modify the stop loss order of a filled trade
- Implement a new dialog for modifying the stop price of a trade
- Introduce new methods in ArgDispatcher for modifying stop prices and setting target prices for trades
- Added `BrokerLog` import to `model` in `trade_action.rs`
- Modified `TradeAction` struct to include `modify_stop` method, currently unimplemented
- Added `build` method to `ModifyStopDialogBuilder` in `modify_stop_dialog.rs`
- Implemented `ModifyStopDialogBuilder::build`
- Modified `display` method in `modify_stop_dialog.rs` to show trade stop update instead of trade submission
- Modified `display` method in `modify_stop_dialog.rs` to show updated stop and remove target and entry
- Added `SearchStopDialogBuilder` method in `modify_stop_dialog.rs` to search for trades with filled status
- Modified `search` method in `modify_stop_dialog.rs` to display trade selection instead of account selection
- Added `stop_price` method in `modify_stop_dialog.rs` to prompt for new stop price input
- Added `modify_stop` method to `TrustFacade` in `lib.rs`, allowing modification of stop price for a trade
- Add a new validation function `can_modify_stop` to check if a trade can be modified
- Modify several functions in `trade_action.rs` to add a check for fees and create a transaction to pay for fees
- Update tests for the new validation function to cover different trade statuses
- Added new methods `update_price` and `update_submitted_at` to the `WorkerOrder` struct in `worker_order.rs`
- Updated `update` and `update_filled_at` methods in `worker_order.rs` to include additional fields in the update query
- Modified `modify_stop` method in `OrderWorker` struct to update stop order price and return the updated order
- Updated methods in `create_stop`, `create_entry`, and `create_target` in `OrderWorker` struct to set different order categories
- Modified `update_status`, `cancel_funded_trade`, and `cancel_submitted_trade` functions in `trade_action.rs` to include additional trade status handling and fund transfers
- Added `update_price` method to `SqliteDatabase` implementation in `database.rs`
- Added `update_price` method to `OrderWrite` trait in `database.rs`
- Added a new module `modify_trade` to `alpaca-broker/src/lib.rs`
- Modified the `modify_stop` function in the `Broker` implementation
- Added a `modify_stop` method to the `TrustFacade` struct
- Updated `ModifyStopDialogBuilder` in `cli/src/dialogs/modify_stop_dialog.rs` to include an `account` field
- Modified various methods in `cli/src/dialogs/modify_stop_dialog.rs` to include calls to `modify_stop` with the `account` parameter
- Made changes to `cli/src/dialogs/modify_stop_dialog.rs` to display updated trade stop and order, and prompt for a new stop price
- Imported `Decimal` and changed the return type of `modify_stop` function in `cli/tests/integration_test_account.rs`
- Modified the `modify_stop` function signature in `model/src/broker.rs` to remove `(Order, BrokerLog)` return type and added `account` parameter
- Added a new file `modify_trade.rs` in `alpaca-broker/src` directory
- Implemented the `modify_stop` function in `alpaca-broker/src/modify_trade.rs` to modify a stop order for a trade
- Made changes in `cli/tests/integration_test_trade.rs` to import `Decimal`, modify various methods, implement `cancel_trade` and `modify_stop` methods, and log modifications in `modify_stop` method
- Made changes in `core/src/workers/trade_action.rs` including conditionals for different status updates, creating transactions for fund transfers, creating target order, and modifying the stop order
- Fixed a typo in the function name `modify_stop` to `modify_entry`
- Changed the field `limit_price` to `stop_price` in the `ChangeReqInit` struct
- Added `TradeCategory` and `Decimal` imports to `validators/trade.rs`
- Added parameter `new_price_stop` and validation for modifying stop price in `can_modify_stop` function in `validators/trade.rs`
- Added error code `TradeValidationErrorCode::StopPriceNotValid` and `TradeValidationError` struct in `validators/trade.rs`
- Added tests for trade validation functions in `validators/trade.rs`
- Added `TradeAction` struct, `update_status`, `fill_trade`, `target_executed`, `stop_executed`, `create_trade`, `stop_trade`, `target_acquired`, `cancel_funded_trade`, `cancel_submitted_trade`, and `modify_stop` functions to `trade_action.rs` in `workers` directory.
…n a long trade

- Added integration test for modifying stop price in a long trade
- Implemented `modify_stop` function in `MockBroker` struct
- Asserted correct trade, account, and new stop price values when calling `modify_stop` function
- Updated stop price to 39 and reflected change in `safety_stop.unit_price` field of trade
- Refactored core/src/workers/order_worker.rs to use new functions and update order categories
- Fixed a typo in cli/src/dialogs/modify_stop_dialog.rs
- Removed unused variable and unnecessary cloning in cli/src/dialogs/modify_stop_dialog.rs
- Improved error message and removed unnecessary cloning in cli/src/dialogs/modify_stop_dialog.rs
- Removed unnecessary context and comments in cli/src/dialogs/modify_stop_dialog.rs
@matiasvillaverde matiasvillaverde merged commit 8b10e76 into main Aug 5, 2023
@matiasvillaverde matiasvillaverde deleted the feature/update-stop branch August 5, 2023 12:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant