Comments (2)
It is like this because you should use the "Droplet" class in order to create a Droplet. For me it is more logical to create a Droplet class instead of doing that inside the Manager... At the beginning I thought that the "manager" should "handle" the process of creation too, but this means that all the other classes makes no sense to exists and I should have only one class that does everything. This is against of the "rule" of writing "better" code that is not repeating and makes more sense. (and is a little diluted )
So at the end of the day you can think to put a new "create_droplet" method inside the Manager class, but if I have to follow the "guidelines" that makes the code more elegant and cleaner, it is a strange thing to me.
from python-digitalocean.
I understand your argument, but I still don't like the duplication of having to use the keys here.
What about:
manager = digitalocean.Manager(client_id="...", api_key="...")
droplet = digitalocean.Droplet(name='Example',
region_id=1, # New York
image_id=2676, # Ubuntu 12.04 x64 Server
size_id=66, # 512MB
backup_active=False)
manager.create_droplet(droplet)
You still have your object creation pattern, and only one place to keep the keys. It is your project, so its totally up to you. The above pattern would just suit my preferences better
from python-digitalocean.
Related Issues (20)
- Load balancer and certificate APIs are returning digitalocean.NotFoundError
- Unable to import module 'Manager' HOT 1
- the API v2 does not seem to provide account name aka team name aka user name. Can advise?
- droplet shutdown is not working HOT 1
- Delete a domain record HOT 4
- Make droplet.create() return a value - so it can be used with 'await' ? HOT 1
- Getting Credits information HOT 1
- No get_actions() for Volume? HOT 1
- Proposing a PR to fix a few small typos
- New release HOT 3
- RedRocket.pssss HOT 1
- Domain.create_new_domain_record ttl kwarg is ignored HOT 1
- Kuberenetes Support HOT 1
- Floating IP Error - digitalocean.DataReadError: HOT 1
- DigitalOcean Api token HOT 2
- Error (400/500) responses with no body raise JSONReadError
- Monitoring metrics from API
- Apps Support
- Add with_droplet_agent support
- Adding type annotation
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from python-digitalocean.