-
Notifications
You must be signed in to change notification settings - Fork 183
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
Relative paths when including templates? #37
Comments
My guess, without digging into it, is because it's poking outside of the template loader directory: https://github.com/mattrobenolt/jinja2-cli/blob/master/jinja2cli/cli.py#L172 Off hand, do you know how this can be worked around? I can expose this as a CLI argument to add additional directories here, but not entirely sure if this can easily just be done for "allow anything". |
We can either just expand the search path to effectively match root, or we can just do a custom Loader that works based on relative from where it's being executed without restriction. |
@mattrobenolt I don't know which of those options is best, but if a custom loader extends some existing loader code and then allows relative loading from the directory containing the Jinja2 template, that sounds like the best option. I don't really know what I'm talking about RE: Python though. I am starting to compare your code and the kolypto / j2cli fork, to see why the j2cli tool does work with relative include paths. |
No worries, I haven't looked at that care, but it doesn't particularly matter. My code is explicitly disallowing it because in most normal uses of Jinja, this is correct/secure behavior. Say, in use of a web server. You don't want things poking into different directories outside of what you define. But in our case, it's a CLI tool and we explicitly are invoking behaviors that we want, not from user input. I'll probably just hack together a quick custom loader that allows this behavior. Thanks for bringing it up! |
I understand now RE: explicit behavior in Jinja, protecting what can be loaded. Thanks for looking into this, I appreciate your time @mattrobenolt. |
I would also find this useful for including common jinja macros to several jinja templates. |
Is there a workaround for this? I've just hit a wall because I can't include templates; I'm using this as part of a build
It doesn't seem to be working for me with absolute paths either |
Ah, okay, I've just noticed this. so I guess I can only load from directories which are below the root template. I'll try that. Okay, that works. Good enough as a workaround 👍 |
Hi, I'm looking into a templating engine to replace my old/outdated/unmaintained one to generete static weg pages. What I had in the old is a directory with templated/includes, and the content directory. And then a make job to generate html pages from the content. I had now a look into jinja2-cli and it seems I've hit this issue (with absolute path instead of relative path). I'm using jinja2-cli as of v0.7.0. As an example:
First line of index.jinja is: And the content of index.env is: The goal in the end is to have 3 directories, the template/include stuff, the content, and the output. The output can then be rsynced to a webserver, without transferring the input/templates too. It also facilitates the cleanup (delete all files in the output directory without worrying about deleting the input/template files). Is this possible with jinja2-cli in the near future? If I read this bugreport it looks like this is not really a priority. Bye, |
I've just seen pull request #76, which seems related to this. Any chance this will go in soon and a new release with this? |
I was using the kolypto / j2cli tool, but am looking to switch to yours. It doesn't appear that it's possible to use relative paths when including templates?
The text was updated successfully, but these errors were encountered: