-
Notifications
You must be signed in to change notification settings - Fork 515
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
Document updates for the Controller Demo and getting it working under python #62
Comments
This section is not sufficiently specific: Follow The Script With both the Alice and Faber agents started, go to the Faber terminal window. The Faber agent has created and displayed an invitation. Copy this invitation and paste it at the Alice prompt. The agents will connect and then show a menu of options: It should say: Copy only the value of the invitation: key from the Invitation Response. Include the bounding curly brackets. Paste in at the Alice prompt for Invite Details. .... |
The menu is wrong The correct menu for Faber is (1) Issue Credential, The correct menu for Alice is (3) Send Message |
The Running Locally instructions are bad. Running Locally To run locally, complete the same steps above for running in docker, except use the following in place of the run_demo commands for starting the two agents. python faber-pg.py 8020 To create the Alice/Faber wallets using postgres storage, just add the "--postgres" option when running the script. Refer to the Follow the Script section below for further instructions. |
I used the python -m from the parent directory to avoid the module not found (due to relative import references) but still get this error Looks like there is still a dependency on indy? that is not installed? import indy.anoncreds $ python3 -m demo.faber 8020 #1 Provision an agent and wallet, get back configuration details |
The offending file is wallet/indy.py with import indy.anoncreds Note that in requirements.txt aiohttp~=3.5.4 There is no dependency on |
Hi @SmithSamuelM, at the moment the recommended approach for running aca-py is to use the provided Dockerfiles. Indy has a number of complicated dependencies so we wrap those up in a docker image. For running the agent locally, please refer to instructions here: https://github.com/hyperledger/aries-cloudagent-python/blob/master/DevReadMe.md#running-locally For running the demo, please refer to the docker instructions here: https://github.com/hyperledger/aries-cloudagent-python/blob/master/demo/README.md#running-in-docker |
Thanks for the pointer but that doesn’t really help me much. I am trying to dig into the code to understand how it works so I can write something for real besides the demos. I want to be able to run the agent demo code locally (not in docker) so I can single step through the code and trace all the calls and dependencies. Especially so I can write my own controller or change the functionality of the agent. It seems the real issue is that the package setup.py requirements.txt has a dependency that is not installed correctly (because its not listed in requirements.txt). What would be most helpful is if you could confirm what version of the PyPI Indy package is the right one and then I can install it. Secondly one reason for my going through the demos is to to help clean up the code. So it seems that you would want to fix the dependency issue not merely tell me to ignore it by using docker images. That you would also want to fix the docker images themselves to be clean instead of having stale dependencies. Also given that all Indy code is now refactored into Indy ledger, Aries and Ursa. It would be nice to know that the dependent code is in the right place. Finally the instructions for the demos conflict with your advice above so it would be good to fix them. To restate could you confirm what the version of PYPI Indy to use to provide the missing dependencies? Thanks |
Sam, the even better answer that will help you even more is learning how to debug when running in docker. Best of both worlds. I think Nick has that nailed. |
@swcurran as far as I can tell the only support for debugging is for Visual Studio debugger and I am on MacOS and don’t use visual studio. It really shouldn’t be hard to get it running locally I can just trial and error the Indy dependencies but I thought your guys would just know which one to use to save me time. Moreover debugging a demo is not the same as doing development. As this is a python repo it should just work with pip install in a virtual environment at the least and not require running docker. Docker is best for deployment not development workflows. It’s one thing to run a functional test with some parts running in docker but unittests should run w/o docker. I am happy to submit pull requests to help it get there. I just don’t yet have visibility into how the refactoring is being done so I am pointing out a problem with a dependency to help clarify if its a real hard dependency or an error and the actual dependency needs to be refactored. And if its in process then telling me what to do in the meantime would be helpful. Thanks |
@SmithSamuelM, gotcha. There are several reasons we lean on Docker heavily: A) Indy is intended to be an optional dependency to aca-py since the project should be agnostic to the ledger identities are anchored in. Indy is only referenced if the agent is run in an "Indy" mode - we will be working to split this out further in the future. B) We use Docker internally for our deployments. C) Installing Indy is not as simple as running But to answer your question: the version of indy currently used is 1.9. The As for the docs - we'll be cleaning those up soon. Thanks for letting us know. |
As it should be. Happy to help. From the docker config it looks like the only issues that really require docker like config are permissions issues for storing private keys which are not so important in development. The rest are just library dependencies for the Indy crypto libraries which should be installable as either wheel packages are explicit dependencies. Using docker just hides making the install architecture clean. It’s more work but worth it in the long run especially when up for broader use.
Nothing wrong with that.
thanks the docker config was informative.
Thanks I will start their
Yes!
=) |
Thanks Sam! |
@ianco - can you please take a look at this one? I can't assign it to you. There are a couple of things referenced in this - the menu, some instructions text and then running locally. I could address the first two, but the last I can't do because, well - you know - I don't have a fan. I'll assign to me, but if you could look, that would be great... |
I think you just need to: pip install python3-indy This is part of the base image when we build the docker image so it's not in requirements.txt Note this will also need libindy.so (shared library binary of the core indy sdk) which you can build from source or download per instructions here: https://github.com/hyperledger/indy-sdk#installing-the-sdk |
The problem of building indy on bare-metal has been a constant pain in this project, which is why very early on we decide docker only. We see countless developers trying to sort these issues out for days just trying to get Indy to running on bare-metal. We've got a pull request in to fix the folders problem, and we'll update the docs to give some guidance on how to run it, but the problem of getting Indy to work on your particular system is going to have to be left to the reader. We'll try to find the pointer to the relevant document in the indy-sdk repo. @SmithSamuelM - the most recent error we have in this chain from you is a the "Indy Module Not Found". If you are past that could you send your latest error? If you think it is in the Aries code, perhaps we could get a pair programming session going on Zoom to try to move this forward? Sorry this is so painful. |
Thanks for following up. I reported my problem in rocket chat I will copy. Here. AGENT_CONFIG_VARIABLE = os.getenv(ENVIRONMENT_VARIABLE_NAME) or INTELLIGENT_DEFAULT In this case a default configuration that always just works may be guaranteed if you design it that way. The success for bare metal (non docker) instantiations becomes much higher and one can write unittests against the set of INTELLIGENT_DEFAULTS That said you guys are doing an awesome job putting out an agent and helping the community. I have spent a lot of time in configuration management of web cloud systems (I was director of R&D for SaltStack for example). A lesson learned is to always have intelligent defaults for configurations and not assume that the environment will be correct. This makes it easier to track down and fix misconfigurations partial or complete without having failures that are not traceable. FWIW: The good: deployment dependencies are minimized. This means that some dependency not under your control will not be able to break the system since the docker image essentially freezes those dependencies. The bad: All dependencies are frozen even the ones your should have control over. When all dependencies are frozen then your development configuration becomes fragile. Development requires making changes and improvements to those dependencies you should have control over. When all dependencies are frozen then developers forget how or why their own dependencies exist so making any change breaks things and its hard to find out why. So dependencies need to be managed in two classes. Dependencies under your control and dependencies not under your control. Not under your control should be frozen and isolated. How they are frozen and isolated is up to the developer. Docker is one way if not the most convenient way because debugging is much harder. (Its remote debug not local) But its an acceptable way. Dependencies under your control need to be fully explicated, automatically tested, and documented. And should be locally run first. This forces developers to understand dependencies they should understand. What I see is that some time in history a combination of insider developers were able to get a docker image that worked and now that docker image is used everywhere without understanding how it works or how to change it or fix it. This is expedient in the short run but becomes a nightmare when trying to get outsider developers to build on top of the system. I suspect that most of these issues on dependencies are not that complex. That its a bunch of environment variables that the docker config sets and the code unfortunately assumes. So at the least explicating those environment configs will make it easy for someone to get a dev environment working. I understand you have limited resources and Indy is complex in its own right and its a huge dependency you don’t control. But the indy environment config you should control since you are using a local Indy Ledger so that should be explicatable. Hope this helps. I want to help and my next wack will be to find all the getenv() calls and see if I can match them up to the docker values for them and see if that makes it work. Any help there would be appreciated. BTW the problem getting indy running is that the build instructions do not detail the specific version set of all the dependent libraries. So a new dev by default will just install the latest version of all the libraries which often means something does not build. And the indy devs are not aggressively testing against latest versions so these problems go undetected. A stable build spec with the versions will allow someone to reproduce a stable build. That is what happened to me. (Rustic 1.26 rusqlite 0.13.0) Docker avoids this problem but makes it must harder to develop against. |
A suggestion: As a long time python developer. The standard practice that Python devs are familiar with and would be more welcoming is to use python virtual environments to freeze dependencies you don’t have control over instead of docker. It makes sense to use docker to run the indy ledger its an external dependency but not the agent. Although your design approach is that the agent should be standalone and the only thing needed is a controller. Its still early for that. And you limit the pool of developers who can help improve the agent. Being python friendly first to a local agent will pay off in the long run. One of my objectives is to figure out how your agent is configured well enough to do that. Hope you don’t mind me asking for help in that regard. |
Thanks for the thoughts, Sam. We are very happy with our choice to be all in on container-based development and we won't be able to go too deep in supporting the range of bare-metal setups that might be used. We're glad to help, and we're very glad to take PRs on how to do that, but we will stick to a Docker/container focus for our dev work. I would add that our take is the use of Docker is VERY developer friendly. We do encounter devs that aren't yet familiar with containers, but we don't find they push back once they are in the flow. That said I'm still amazed that remote debugging isn't better than it is... :-) Our experience in the last 18 months of doing Indy development has continually re-enforced our chosen approach. We have seen many, many developers show up and die on the hill of trying to get things to run on bare-metal. We did a couple of things that helped in avoiding that fate. We deliberately had developers focused on getting underlying components in place for others, so the others didn't have to worry about that level of detail to deliver. That got us delivering value, vs. getting things working. Second, to your point on dependencies - we keep a keen focus on what is changing in the dependencies and continue to move them forward. Things are working before they are presented to other devs, but at the same time they track whats been released. However, if a developer is not developing something, they do not use the master branch - they use the last release. We are completely up to date on Indy within hours/days of a new release. We have pioneers that check out the changes and account for them in the artifacts we build. The rest of the developers only need to know what they need to know to keep delivering. We're pretty confident that the result is that we deliver far faster and we spend way less time on local issues. Any productivity improvement is immediately available to the rest of the team. Note that our container strategy goes right to production. We have an Openshift (aka Kubernetes) environment and all of our work is pretty rapidly pushed to production. We have (at last count) 7 different streams that go to production, all going through dev, test and into prod. The consistency from the developers desk to production enabled by containers is too useful to give up. Let alone that our build and test automation along the way is all container based. Anyway, I'm sure you know about all that. |
@swcurran thanks for the detailed explanation. Docker is popular and capable enough that I can see it being chosen as a hard dependency; with good reason. =) Docker first, only, and always. Which means only remote debugging and only docker deployment. That would also naturally but unnecessarily tend toward hard dependency on Docker injection of environment dependencies even in dev. My confusion with that is how to reconcile the fact that the Alice Faber demo explicitly includes instructions for running the Faber and Alice agents locally without docker as a hard dependency for them. As far as I can tell from the bugs I encountered, the local running can’t work as provided. I assumed that indeed local running was a supported and tested option and that whoever documented it could help me get it running by being more explicit in describing the tested configuration and environment that allowed them to run it locally. What I am hearing suggests that that is not possible? I was in good faith working through the problems I encountered which likely would be due to differences in the setup and configuration but not documented in the tutorial as requirements to running locally. So it seems that either the tutorial needs to be changed to state that running locally is not supported as in try at your own risk or whoever on your end is able to run it locally could help by being more complete in the description of their successfully locally non-docker running configuration. =). Unfortunately because I anticipate some future development and deployment applications that require running non docker agents I am hopeful and grateful for your continued help in this regard. |
We have the demo running locally on a mac with the most recent code update
using the most recent documentation updates. Have you given that a try?
We're glad to help out with the issues you are having - please spin it up,
and send us the init setup and log (debug level). We can also get on a
Zoom session with you to debug it. We got logs yesterday and think we have
a fix for a "time out too short" issue discovered with the user having
trouble on a Raspberry Pi.
There's no reason it shouldn't work running locally - just that our team
will be using docker for development. Others are welcome to use other
techniques and point out any issues if we have a problem.
FYI - we are planning on splitting the demo into two separate proesses -
the controller and the agent. This will change from the agent currently
being a sub-process of the controller. We'll use docker compose for the
management of that.
Sorry for the delay on this - we definitely want this to be smooth and easy.
…On Fri, Jul 19, 2019 at 6:41 AM Samuel Smith ***@***.***> wrote:
@swcurran <https://github.com/swcurran> thanks for the detailed
explanation. Docker is popular and capable enough that I can see it being
chosen as a hard dependency; with good reason. =) Docker first, only, and
always. Which means only remote debugging and only docker deployment. That
would also naturally but unnecessarily tend toward hard dependency on
Docker injection of environment dependencies even in dev. My confusion with
that is how to reconcile the fact that the Alice Faber demo explicitly
includes instructions for running the Faber and Alice agents locally
without docker as a hard dependency for them. As far as I can tell from the
bugs I encountered, the local running can’t work as provided. I assumed
that indeed local running was a supported and tested option and that
whoever documented it could help me get it running by being more explicit
in describing the tested configuration and environment that allowed them to
run it locally. What I am hearing suggests that that is not possible? I was
in good faith working through the problems I encountered which likely would
be due to differences in the setup and configuration but not documented in
the tutorial as requirements to running locally. So it seems that either
the tutorial needs to be changed to state that running locally is not
supported as in try at your own risk or whoever on your end is able to run
it locally could help by being more complete in the description of their
successfully locally non-docker running configuration. =). Unfortunately
because I anticipate some future development and deployment applications
that require running non docker agents I am hopeful and grateful for your
continued help in this regard.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#62>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAHYRQWA6E2SKYG2UVUYY43QAHACHANCNFSM4IBS2RVA>
.
|
Thank @swcurran I had some other stuff keep me busy last couple of days. I will update to the latest version and try again. The zoom call offer is much appreciated. =) |
I think we are pretty good with this issue and am closing. |
Update: decided to edit response, apologies was just frustrated. |
Should change readme.md to include explicit link to von-network setup page where it says to start up von-network
https://github.com/bcgov/von-network#running-the-network-locally
The text was updated successfully, but these errors were encountered: