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

Add dependency on jekyll-last-modified-at #119

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

aepstein
Copy link

@aepstein aepstein commented Feb 5, 2015

Add jekyll-last-modified-at to make it easier to time stamp built pages. Currently this requires us to do a static build locally, but it seems like a feature that would be widely used.

Add jekyll-last-modified-at to make it easier to time stamp built pages.  Currently this requires us to do a static build locally, but it seems like a feature that would be widely used.
@benbalter
Copy link
Contributor

@gjtorikian, any strong opinions here?

@parkr
Copy link
Contributor

parkr commented Feb 6, 2015

👍 ✖️ 💯

@aepstein 👋 from a former Cornell student!

@benbalter There might be some security concerns around the files passed to git, but I'm sure they can be adequately mitigated.

@gjtorikian
Copy link
Contributor

Unfortunately, this plugin simply does not work on GitHub Pages: gjtorikian/jekyll-last-modified-at#32

We've looked into it; the Pages instance only clones with a depth of 1. You'll need to build this locally and push it up, as with other plugins.

@ghost
Copy link

ghost commented Mar 1, 2017

That's strange. I just used it on an item in a collection today and it only updated the last modified date for that one item. I left a comment here: gjtorikian/jekyll-last-modified-at#32

I feel it would be very beneficial to have this plug-in as a part of the Pages gem.

@ghost
Copy link

ghost commented Mar 1, 2017

@parkr would you mind reopening this until there's been some further investigation?

@gjtorikian gjtorikian reopened this Mar 1, 2017
@gjtorikian
Copy link
Contributor

This PR should go up to 1.0.1; not sure if you have the time for that @aepstein.

Things have changed so much in the last couple of years that this may be working again. Who knows, let's found out!

@benbalter
Copy link
Contributor

@gjtorikian will this work with a shallow (e.g., --depth 1) clone?

@gjtorikian
Copy link
Contributor

will this work with a shallow (e.g., --depth 1) clone?

I truly have no idea.

@JHabdas' comment is:

I started using this gem yesterday and can confirm, at least for collections, it pulls the timestamp from the individual asset.

I hate to pull the "not my team!" card, but, I am pretty busy at work at the moment and don't have the time to give this a thorough testing. Mostly because I am no longer sure how the internals of Jekyll/Pages work.

@parkr
Copy link
Contributor

parkr commented Mar 1, 2017

We pull with --depth 1 and I can confirm that this breaks expected behaviour (i.e. in all cases the date is the exact same since we're only working with 1 commit of history). We clone with that depth to make builds faster and to improve reliability on our systems, so the potential path forward here would be to make use of the Git API and fetch the date of the latest commit on that file. It would be terribly inefficient if you did this for every page, however. Perhaps we could add this to the site.github gem (jellyll/github-metadata) as site.github.commit_dates[<filepath>] and read them all in bulk from the GraphQL API. Is that possible, @gjtorikian?

@ghost
Copy link

ghost commented Mar 2, 2017

Aside: My testing was not on GH Pages, but using Git itself with a Cloud CMS for editing from a Web-based GUI which preserves individual file history.

@gjtorikian
Copy link
Contributor

Is that possible, @gjtorikian?

It should be technically possible. Moreover, right now, given a Git tree, you could list all the entries in that tree via GraphQL. I don't know if that's useful though.

@jimkohl
Copy link

jimkohl commented Sep 5, 2017

Thanks Pat for the references. Apologies for the unnecessary issue!

--depth 1 will just grab branch tips and unless I'm missing something that will work ok for publishing purposes.

So I brought this into my local jekyll and it seems to be grabbing the timestamps correctly.

But it adds a bunch of time to startup as noted. However I'm wondering if it would be possible to whitelist as-is until said optimization above is avail (great idea and willing to assist).

That way we could still use it in the interim. Thoughts?

@ghost
Copy link

ghost commented Sep 9, 2017

Taking a fresh look at this. Modified dates are a fundamental part of the web and should be worked into core for majority benefit—not just GH pages.

@divadsn
Copy link

divadsn commented Oct 26, 2017

Highly awaiting this gem to be working, it should be a basic thing in times of modern websites. 😄

@jayvdb
Copy link

jayvdb commented Mar 6, 2018

Note there are some very serious problems with the plugin, especially its test suite, that need fixing before this should be whitelisted or added as a dependency.
See PRs and issues that I have raised in its repo.

@fingolfin
Copy link

I made an update version of this PR (see here for the relevant tree), but then realized this issue is still blocked by the fact that git rev-parse won't work as desired in the GitHub Page settings, due to shallow clones being used.

And it seems jekyll/github-metadata#130 also went nowhere so far (due to a lack of volunteers with the time and skills to implement it, I guess). Pity :-(

@nisbet-hubbard
Copy link

See #838 (comment) for a different way to automate last_modified_at.

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.

9 participants