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

Create new connector for Theme Editor #313

Closed
frankiejarrett opened this issue Mar 8, 2014 · 15 comments · Fixed by #341
Closed

Create new connector for Theme Editor #313

frankiejarrett opened this issue Mar 8, 2014 · 15 comments · Fixed by #341

Comments

@frankiejarrett
Copy link
Contributor

When changes are made to theme files via the Appearance > Editor screen these should be logged by Stream.

In fact, this could be one of the most important areas to track because it's the easiest place to completely break your site! 😩

screen shot 2014-03-07 at 10 20 02 pm

  1. The connector name should be Theme Editor
  2. The file name should be stored in stream_meta and appear in the Summary
  3. The context should be the Theme name

screen shot 2014-03-07 at 10 18 30 pm

@lukecarbis
Copy link
Contributor

Wouldn't it be cool if Stream included the diff? Wow, that's a slippery slope.

@frankiejarrett
Copy link
Contributor Author

Yeah @westonruter has suggested this before, it would be quite involved! But awesome. 😎

@shadyvb
Copy link
Contributor

shadyvb commented Mar 10, 2014

I'm not sure if there is actions/filters for that, would probably need a workaround to log it.

@powelski powelski self-assigned this Mar 13, 2014
@powelski
Copy link

I made it work this way:

  1. On client side, hidden textarea is created with oldcontent name (as opposite of newcontent name of existing textarea) and contents of existing textarea
  2. On wp_redirect filter, if it's Editor page and data is sent, real file contents are compared to $_POST['oldcontent'] changes are logged.

I decided to do so, to make sure changes have been really saved to file, to prevent situation when there was some problem with the file while saving and we log unexisting changes.

Using wp_redirect filteris not most intuitive to use here, but it's the only one hook available after saving the file and I wanted to do it immediately.

I think showing changes is great idea - we would need to create space in database for that, because currently there are no fields of such capacity.

@powelski
Copy link

@fjarrett @shadyvb @lukecarbis I changed the way it works. It doesn't use client-side anymore. Instead, I made it use static field in the class, which keeps all needed data on load-theme-editor.php hook if only correct post data is found. Then, on wp_redirect this is compared to actual file contents and logged if it's different.

We would need to discuss keeping contents in database to enable showing diffs. My suggestion is to change type of meta_value field in stream_meta table from VARCHAR to LONGTEXT. This type is used in postmeta and usermeta anyway. That would be perfect place to keep contents or deltas - this is to be discussed.

@powelski
Copy link

Screenshot:
editor log

@westonruter
Copy link
Contributor

@powelski:

We would need to discuss keeping contents in database to enable showing diffs. My suggestion is to change type of meta_value field in stream_meta table from VARCHAR to LONGTEXT. This type is used in postmeta and usermeta anyway. That would be perfect place to keep contents or deltas - this is to be discussed.

A concern with this is it would make stream_meta.meta_value largely unindexable, and so could slow down queries quite a bit. But I'm not sure how many joins are being done on meta_value fields.

@frankiejarrett
Copy link
Contributor Author

@powelski @westonruter I don't envision Stream ever storing heavy amounts of previous values like this out-of-the-box. That type of functionality would probably best exist as a separate extension project.

@shadyvb
Copy link
Contributor

shadyvb commented Mar 14, 2014

+1 for @westonruter, this was decided on building the architecture, losing the index will slow down queries, was one of the reasons why we went for our own db tables.

@shadyvb
Copy link
Contributor

shadyvb commented Mar 14, 2014

Yea, so i guess just adding the record will be it for now, a filter would be great so others can hook in and see what changed.

@frankiejarrett
Copy link
Contributor Author

@shadyvb Yeah that's right, I think the only requirement here (for now) is to add a connector and create basic records when changes happen.

@westonruter
Copy link
Contributor

Or what about storing the diff? Sure it would likely get truncated, but if you could at least see some context for what was removed or added, at least an excerpt of it, this could be useful. But yeah, also makes sense if this feature was deferred to something that could track the complete previous values.

@powelski
Copy link

@westonruter I think we should wait for the real extension then. 256 chars is very small to rely on, even for diff excerpts.

@powelski
Copy link

Guys, I'm opening pull request for this task. If you are thinking about any enhancements, please share your thoughts.

BTW, I needed to turn off similar feature of Installer connector. It logged jobs from Editor as well, but even if no changes have been really made.

@powelski
Copy link

@fjarrett Please review the pull request.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants