-
Notifications
You must be signed in to change notification settings - Fork 9.6k
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
Implemented new http
data-source to deal with external HTTP endpoints
#14270
Implemented new http
data-source to deal with external HTTP endpoints
#14270
Conversation
Hi @korotovsky! Thanks for working on this. Your use-case here makes a lot of sense to me, and I agree that having a simple way to retrieve data over HTTP would be useful. Previous experience with the I would suggest to instead address this use-case via a data source: data "http" "example" {
url = "https://gist.githubusercontent.com/anonymous/a738a343ef2a44c1bafe69b72b9a69dc/raw/0aa990256dfc682ade55c9f2614ff20689512d88/1.0.0"
}
resource "null_resource" "service-provisioner" {
triggers {
instance_count = "${var.some_var}"
version = "${data.http.example.body}"
# ...
}
provisioner "remote-exec" {
# ...
}
} While this is definitely more verbose, it has the benefit that the HTTP get participates in the dependency graph along with everything else, so it will get retrieved just once when refreshing the data sources and the timing of that GET can be influenced by resource dependencies. I appreciate the work you already put into this so I don't mean to suggest by this that I expect you to start over and implement this data source instead. However, if you are interested in working on it, I would suggest making it behave similarly to the existing It would be totally reasonable for you to say that you've got no further time to spend on this: no pressure whatsoever. If this rework is not something you can take on, please let me know and I can try to find a place for this on my personal to-do list, since I agree it's a good thing to support. Thanks again! |
url(string)
interpolation function for reading remote content.http
data-source to deal with external HTTP endpoints
9ef0ecd
to
97b72c7
Compare
Hi @apparentlymart, All done (I hope). Some notes: I copied the function Thanks. |
Thanks for this new version, @korotovsky! On a first pass it all looked good to me. I'll take another closer look soon when I have some more time to review/test, and then we can get this merged. |
97b72c7
to
c3f1784
Compare
Thanks again, @korotovsky! Before I merged I made some small adjustments to the documentation, and I renamed the Awesome work here! I especially liked how the unit tests bring their own temporary web server so that they can run in a self-contained way. |
I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues. If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further. |
Hi,
First, thanks for creating the Terraform tool!
I would like to purpose next enhancement for Terraform. Sometimes it's not possible to re-create and provision resources from scratch and for that purpose we use
null_recourse
+triggers
combination to run provisioners. But also we have some additional external metadata in our centralized registry and when data is changed there, then on next run Terraform will re-run provisioners again.Here is an example:
To achieve this behavior I've added the
url(string)
interpolation function. I've also added some tests, docs have been updated.Thanks.