How to create a macOS High Sierra VM with VirtualBox
Published 2017-11-24, 00:43
- macOS host system:
http://tobiwashere.de/2017/10/virtualbox-how-to-create-a-macos-high-sierra-vm-to-run-on-a-mac-host-system/ - Windows host system:
https://www.howtogeek.com/289594/how-to-install-macos-sierra-in-virtualbox-on-windows-10/
Move (clone and close) Github issues to a different repository
Published 2017-08-04, 11:45
If you have any projects on Github that span multiple repositories you know the pain when someone creates a valid issue, but uses the wrong repo to do so. Of course you could tell them to „Create another issue in the correct repo and gtfo“ but that a) wouldn’t be very nice and b) is a quite a lot of work and c) probably wouldn’t have the intended effect to grow your Github community.
So you need a way to move issues betweens repos.
Github doesn’t support this out of the box, but of course some other people jumped in and created things that do. Here is an overview of my research on this:
- Github Issue Mover
github-issue-mover.appspot.com / github.com/google/github-issue-mover
Almost a classic, started in 2014, this tools allows you to paste the source issue and target repo to be moved and then does the job. - Kamino
chrome.google.com/webstore/detail/kamino/ffdebockfdjileaojbbccofhgncmioaf / github.com/gatewayapps/kamino
This Chrome extension is „better“ in that it adds the „move issue“ button directly to the Github issue page and also remembers the last 5 used repos. - Zenhub seems to have a „Move Issue“ button if you use their tool.
- github-issues-import is an old but trusty Python script that can do the job for one or many issues.
How to develop iOS 10.3.x apps in Xcode 8.2.x
Published 2017-07-10, 18:44
If you work on an older version of Mac OS, for example because Apple decided your Macbook is to old to upgrade to a recent version, you might be stuck with Xcode 8.2.x to develop and test your iOS apps. Unfortunately this can lead to this nice error message if you made the mistake to upgrade your iPhone to iOS 10.3:
Could not locate device support files
This iPhone 6s is running iOS 10.3.1 (14E304), which may not be supported by this version of Xcode.
This is because the old Xcode doesn’t get these „device support files“ via updates any more. Luckily the internet is here to rescue you.
- Download https://www.dropbox.com/s/i1f7q8w3vgr2ozl/10.3%20%2814E269%29.zip?dl=0 and extract it
- Click on „Finder“ in MAC OS
- Click on „Go to Folder“
- Paste this path:
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/DeviceSupport- Paste your extracted „10.3 (14E269)“ directory to that place.
- Quit Xcode and restart it (and maybe the whole Mac).
- You can now run your projects successfully on your real device again.
Adapted from source: https://gist.github.com/steipete/d9b44d8e9f341e81414e86d7ff8fb62d#gistcomment-2041802
Overview of the trakt.tv API Concepts and Endpoints
Published 2017-07-03, 17:24
trakt.tv offers a very comprehensive API with an amazing documentation. But thorough as it is – and the technical details like authentication, data formats, parameters etc. are really, really well covered – it can also feel a bit overwhelming when you jump in and want to get a first overview, or are only looking for some specific data or type of data.
As I just did exactly that, I went through the whole documentation and extracted the most relevant information. The order of this article, especially the API endpoints, follows the official API documentation. I only added some more headlines to group the endpoints in a better way:
Concepts
The API only defines some terms in „Terminology“, but there is a lot more to understand what there is and how it is all connected:
- There are Users and objects: Movies, Shows with Seasons and Episodes.
- Users
- Users can watch things:
- Users can checkin to or scrobble movies and episodes. These are then first marked as watching, later as watched after the runtime (complicated, read details in docs).
- Users can additionally add to history for movies, shows, seasons and episodes to mark them as watched instantly.
- Users can create multiple Lists and have one Collection and one Watchlist (of movies, shows, seasons, and episodes).
- Users can write Comments on movies, shows, seasons, episodes, or lists.
- Users can create Replies and Likes on comments and lists.
- Users can create Replies and Likes on comments and lists.
- Users can create Ratings on movies, shows, seasons and episode.
- Users have Settings and a Profile
- Users can follow other users to create Follower Requests and eventually become Followers, Following and Friends
- Users can watch things:
- Objects
- There is additional information for some objects:
- Summary for movies, people, shows, seasons and episodes collect all known information about them
- Aliases of movies and shows
- Releases of movies
- Translations of movies, shows and episodes
- People are cast and crew of shows and movies
- Search can look for movies, shows, episodes, people, and lists by text or ID.
- Related objects are calculated for movies and shows.
- Stats are calculated for movies, shows, seasons, episodes and users.
- There is additional information for some objects:
- Users and Objects
- History and Playback are calculated based on checkins and scrobbles (= movies and episodes watched) and manual „add to history“.
- Last Activities are collected from history and all other user activities (comments, replies, likes, ratings).
- Based on the releases of objects and the history of the user there are Calendars for shows and episodes.
- Recommendations are given to users for movies and shows.
- Collection Progress and Watch Progress is calculated for users for shows and their episodes.
- Users can create Hidden Items to hide things (movies, shows or episodes) in calendars, collection progress, watch progress and recommendations.
Use the checkboxes next to the terms to deactivate them in the list below. You can also set if they only should be deactivated or completely hidden.
Emojis Legend
These Emojis are used in the official documentation to indicate what functionality is offered by or needed for an endpoint.
- 📄 = Pagination
- 📄? = optional
- ✨ = Extended Info
- 🎚 = Filters
- 🔒 = OAuth
- 🔒? = optional
- 🔒! = required
Data Endpoints
These return the nitty-gritty of Trakt: Lots of data about shows and movies and all the things related to them:
- Calendars
- All Shows ✨ 🎚 – Returns all shows airing during the time period specified.
- All New Shows ✨ 🎚 – Returns all new show premieres (season 1, episode 1) airing during the time period specified.
- All Season Premieres ✨ 🎚 – Returns all show premieres (any season, episode 1) airing during the time period specified.
- All Movies ✨ 🎚 – Returns all movies with a release date during the time period specified.
- All DVD ✨ 🎚 – Returns all movies with a DVD release date during the time period specified.
- Checkin
- n/a
- Comments
- Movies
- Movies
- Trending 📄 ✨ 🎚 – Returns all movies being watched right now.
- Played 📄 ✨ 🎚 – Returns the most played (a single user can watch multiple times) movie.
- Watched 📄 ✨ 🎚 – Returns the most watched (unique users) movies.
- Collected 📄 ✨ 🎚 – Returns the most collected (unique users) movies.
- Anticipated 📄 ✨ 🎚 – Returns the most anticipated movies based on the number of lists a movie appears on.
- Box Office ✨ – Returns the top 10 grossing movies in the U.S. box office last weekend.
- Updates 📄 ✨ – Returns all movies updated since the specified UTC date.
- Movie
- Summary ✨ – Returns a single movie’s details.
- Aliases – Returns all title aliases for a movie.
- Releases – Returns all releases for a movie including country, certification, release date, release type, and note.
- Translations – Returns all translations for a movie, including language and translated values for title, tagline and overview.
- Comments 📄 – Returns all top level comments for a movie.
- Lists 📄 – Returns all lists that contain this movie.
- People ✨ – Returns all cast and crew for a movie.
- Stats – Returns lots of movie stats.
- Watching ✨ – Returns all users watching this movie right now.
- Movies
- People
- Recommendations
- n/a
- Scrobble
- n/a
- Search
- Text Query 📄 ✨ 🎚 – Search all text fields that a media object contains (i.e. title, overview, etc).
- ID Lookup 📄 ✨ – Lookup items by their Trakt, IMDB, TMDB, TVDB, or TVRage ID.
- Shows
- Shows
- Trending 📄 ✨ 🎚 – Returns all shows being watched right now.
- Played 📄 ✨ 🎚 – Returns the most played (a single user can watch multiple episodes multiple times) shows.
- Watched 📄 ✨ 🎚 – Returns the most watched (unique users) shows.
- Collected 📄 ✨ 🎚 – Returns the most collected (unique users) shows.
- Anticipated 📄 ✨ 🎚 – Returns the most anticipated shows based on the number of lists a show appears on.
- Updates 📄 ✨ – Returns all shows updated since the specified UTC date.
- Show
- Summary ✨ – Returns a single show’s details.
- Aliases – Returns all title aliases for a show.
- Translations – Returns all translations for a show, including language and translated values for title and overview.
- Comments 📄 – Returns all top level comments for a show.
- Lists 📄 – Returns all lists that contain this show.
- People ✨ – Returns all cast and crew for a show.
- Stats – Returns lots of show stats.
- Watching ✨ – Returns all users watching this show right now.
- Next Episode ✨ – Returns the next scheduled to air episode.
- Last Episode ✨ – Returns the most recently aired episode.
- Shows
- Seasons
- Seasons
- Summary ✨ – Returns all seasons for a show including the number of episodes in each season.
- Season
- Seasons
- Episodes
- Episode
- Summary ✨ – Returns a single episode’s details.
- Translations – Returns all translations for an episode, including language and translated values for title and overview.
- Comments 📄 – Returns all top level comments for an episode.
- Lists 📄 – Returns all lists that contain this episode.
- Stats – Returns lots of episode stats.
- Watching ✨ – Returns all users watching this episode right now.
- Episode
- Sync
- n/a
- Users
- Profile 🔒? ✨ – Get a user’s profile information.
- Collection 🔒? ✨ – Get all collected items in a user’s collection.
- Comments 🔒? 📄 ✨ – Returns comments a user has posted sorted by most recent.
- Lists
- Lists
- Get 🔒? – Returns all custom lists for a user.
- List
- Get 🔒? – Returns a single custom list.
- List Item
- List Items 🔒? 📄? ✨ – Get all items on a custom list.
- List comment 📄 – Returns all top level comments for a list.
- Lists
- Follow
- History 🔒? 📄 ✨ – Returns movies and episodes that a user has watched, sorted by most recent.
- Watchlist 🔒? 📄? ✨ – Returns all items in a user’s watchlist filtered by type.
- Watching 🔒? ✨ – Returns a movie or episode if the user is currently watching something.
- Watched 🔒? ✨ – Returns all movies or shows a user has watched sorted by most plays.
- Stats 🔒? – Returns stats about the movies, shows, and episodes a user has watched, collected, and rated.
User Endoints
If it matters which user is logged in via OAuth, these endpoints are collected here:
- Calendars
- My Shows 🔒! ✨ 🎚 – Returns all shows airing during the time period specified.
- My New Shows 🔒! ✨ 🎚 – Returns all new show premieres (season 1, episode 1) airing during the time period specified.
- My Season Premieres 🔒! ✨ 🎚 – Returns all show premieres (any season, episode 1) airing during the time period specified.
- My Movies 🔒! ✨ 🎚 – Returns all movies with a release date during the time period specified.
- My DVD 🔒! ✨ 🎚 – Returns all movies with a DVD release date during the time period specified.
- Checkin
- Checkin 🔒! – Check into a movie or episode.
- Delete 🔒! – Removes any active checkins, no need to provide a specific item.
- Comments
- Comments
- Post a comment 🔒! – Add a new comment to a movie, show, season, episode, or list.
- Comment
- Update 🔒! – Update a single comment created within the last hour
- Delete 🔒! – Delete a single comment created within the last hour.
- Replies
- Post 🔒! – Add a new reply to an existing comment.
- Like
- Like 🔒! – Votes help determine popular comments.
- Remove 🔒! – Remove a like on a comment.
- Comments
- Movies
- n/a
- People
- n/a
- Recommendations
- Movies 🔒! ✨ – Personalized movie recommendations for a user.
- Hide Movie 🔒! – Hide a movie from getting recommended anymore.
- Shows 🔒! ✨ – Personalized show recommendations for a user.
- Hide Show 🔒! – Hide a show from getting recommended anymore.
- Scrobble
- Search
- n/a
- Shows
- Show
- Collection Progress 🔒! – Returns collection progress for a show including details on all aired seasons and episodes.
- Watched Progress 🔒! – Returns watched progress for a show including details on all aired seasons and episodes.
- Show
- Seasons
- n/a
- Episodes
- n/a
- Sync
- Last Activities 🔒! – Returns a list of dates when the user last interacted with trakt.tv for different object types.
- Get Watched 🔒! ✨ – Returns all movies or shows a user has watched sorted by most plays.
- Playback
- Playback 🔒! – Whenever a scrobble is paused, the playback progress is saved.
- Remove Playback 🔒! – Remove a playback item from a user’s playback progress list.
- Collection
- Get Collection 🔒! ✨ – Get all collected items in a user’s collection.
- Add to Collection 🔒! – Add items to a user’s collection.
- Remove from Collection 🔒! – Remove one or more items from a user’s collection.
- History
- Get History 🔒! 📄 ✨ – Returns movies and episodes that a user has watched, sorted by most recent.
- Add to History 🔒! – Add items to a user’s watch history.
- Remove from History 🔒! – Remove items from a user’s watch history including all watches, scrobbles, and checkins.
- Watchlist
- Get Watchlist 🔒! 📄? ✨ – Returns all items in a user’s watchlist filtered by type.
- Add to Watchlist 🔒! – Add one of more items to a user’s watchlist.
- Remove from Watchlist 🔒! – Remove one or more items from a user’s watchlist.
- Users
- Settings 🔒! – Get the user’s settings so you can align your app’s experience with what they’re used to on the trakt website.
- Follower Requests
- Follower Requests 🔒! ✨ – List a user’s pending follow requests so they can either approve or deny them.
- Approve or Deny Follower Requests
- Approve 🔒! – Approve a follower.
- Deny 🔒! – Deny a follower.
- Hidden Items
- Hidden Items 🔒! 📄 ✨ – Get hidden items for a section.
- Add Hidden Items 🔒! – Hide items for a specific section.
- Remove Hidden Items 🔒! – Unhide items for a specific section.
- Likes 🔒! 📄 – Get items a user likes.
- Profile 🔒? ✨ – Get a user’s profile information.
- Collection 🔒? ✨ – Get all collected items in a user’s collection.
- Comments 🔒? 📄 ✨ – Returns comments a user has posted sorted by most recent.
- Lists
- Lists
- Get 🔒? – Returns all custom lists for a user.
- Create 🔒! – Create a new custom list.
- List
- Get 🔒? – Returns a single custom list.
- Update 🔒! – Update a custom list by sending 1 or more parameters.
- Delete 🔒! – Remove a custom list and all items it contains.
- List Like
- Like 🔒! – Votes help determine popular lists.
- Remove 🔒! – Remove a like on a list.
- List Item
- List Items 🔒? 📄? ✨ – Get all items on a custom list.
- Add List Item 🔒! – Add one or more items to a custom list.
- Remove List Item 🔒! – Remove one or more items from a custom list.
- Lists
- Follow
- Follow
- Follow 🔒! – Follow a user.
- Unfollow 🔒! – Unfollow someone you already follow.
- Followers 🔒? ✨ – Returns all followers including when the relationship began.
- Following 🔒? ✨ – Returns all user’s they follow including when the relationship began.
- Friends 🔒? ✨ – Returns all friends for a user including when the relationship began.
- Follow
- History 🔒? 📄 ✨ – Returns movies and episodes that a user has watched, sorted by most recent.
- Watchlist 🔒? 📄? ✨ – Returns all items in a user’s watchlist filtered by type.
- Watching 🔒? ✨ – Returns a movie or episode if the user is currently watching something.
- Watched 🔒? ✨ – Returns all movies or shows a user has watched sorted by most plays.
- Stats 🔒? – Returns stats about the movies, shows, and episodes a user has watched, collected, and rated.
Master Data Endpoints
These endpoints offer mostly static data that should be retrieved once and then be cached for further use:
- Certifications
- List – Get a list of all certifications, including names, slugs, and descriptions.
- Genres
- List – Get a list of all genres, including names and slugs.
- Networks
- List – Get a list of all TV networks, including the name.
And that’s it! All essential API endpoints of the trakt.tv API, groupd by type and explained a bit more.
(Visual) CMS for Jekyll
Published 2017-06-22, 12:20
Jekyll is „a blog-aware, static site generator in Ruby“. It also is used by Github Pages, which means you can host simple static sites, managed via Git, for free with it. That’s great.
Not that great (for me) is that you have to manage the content in the file system and manually handle Markdown files. That’s why there are multiple visual, hosted CMS for Jekyll.
I looked at some of them:
- Siteleaf is a nice hosted application that offers a structured view of your Jekyll files. Collections get their own navigation entries, the Markdown editor is decent (although
superpretty small with no fullscreen or „show the relevant stuff only“ option), even their visual editor (beta) doesn’t seem to bad.
Unfortunately it is unusable for me as it messes with the front matter (resorts the entries) and _config.yml (also resorts and removes all comments) the moment you add the repository to siteleaf. Boo!Their collection view also doesn’t understand sub-folders and just ignores them.
The free plan is limited to 100 pages.
- Forestry does the same things as Siteleaf, but a lot better. Collections get their navigation, show the subfolders, front matter and config files stay untouched. The markdown and WYSIWYG editors are… okayish. Markdown view has a few strange bugs and although WYSIWYG is a great preview, using it to edit can break stuff quite fast. Switching between the two also can cause loss of data. Again the real editor is much too small, no fullscreen or „writing mode“ view – I don’t understand why this is not the focus.
Their team is very responsive via Intercom and also seems to fix bugs quite frequently. Let’s hope they continue doing so, then this could get pretty nice.
- cloudcannon is a different beast – it actually manages to make your rendered pages editable in their „Visual Editor“. Unfortunately advanced stuff like Automated „Table of Contents“ Generation of kramdown gets overwritten by this. The „Content Editor“ (WYSIWYG without my design) has the same problem and the „Source Editor“ is very sourcy and feels more like an programming IDE.Besides that the Editors are awesome, really great work from the team. You can hide all the UI to make a very focused write environment and everything seems very well thought out.
- Prose has no visual editor, no „structured“ view of the file system – but it just works. You can edit files, preview the Markdown, commit it to Github. The editor view is very clean and simple which makes for a great full screen experience. Before saving you also have a „diff“ view, that – although a bit rudimentary – gives a great overview of the changes you (accidentally?) created.
Although hosted on prose.io, Prose is also open source (since 2012!) and can be hosted on your own server. The instance on prose.io is great though, and you can (ab)use the Github issues as a support channel if needed. Nice people.
(A more complete list is at headlessCMS.org.)
So because of the shortcomings of Siteleaf (unusable because of messing with my data), Forestry (buggy editors) and Cloudcanon (doesn’t support advanced stuff) I am actually using Prose right now.
(Of course there also several options you can self host, but as that kind of defeats the purpose to go to a Github Pages hosted static site – now I have o host the CMS myself – I skipped those. Still, some links: MeetHyde, jekyll-admin)
YouTube RSS Feeds
Published 2017-04-23, 22:47
- https://www.youtube.com/feeds/videos.xml?channel_id=CHANNELID
- https://www.youtube.com/feeds/videos.xml?user=USERNAME
- https://www.youtube.com/feeds/videos.xml?playlist_id=YOUR_YOUTUBE_PLAYLIST_NUMBER
Source: http://stackoverflow.com/a/31535120
Mac OS X: Unabhängige Scroll-Richtung für Maus und Touchpad
Published 2017-04-04, 12:28
Natural Scrolling ist toll auf Mac OS X. Allerdings nur mit dem Touchpad, nicht mit der angeschlossenen USB-Maus. Dummerweise sind die „Scroll Direction“-Einstellungen von Maus und Touchpad aneinander gekoppelt, so dass wenn die eine (de)aktiviert wird, die andere dies auch tut.
Heute aber eine Lösung gefunden: https://pilotmoon.com/scrollreverser/
Installiert, konfiguriert, Problem behoben.
Remove security from a secured PDF file
Published 2017-03-07, 21:41
One of my banks stopped offering downloadable CSV files of the statements af account. Bastards.
Luckily they still offer the monthly statement as a PDF. Parse that (parsing PDFs always is a pain, but possible), you have a CSV.
…
Unfortunately the PDFs offered for download are Secured PDF files. And most PDF parsing libraries can’t or don’t want to handle secured files.
„Well, bank statements are sensitive information!“ you might say. Yes they are. So I would understand if they used a security setting that requires a password to open a file. But they don’t do that. The file is just secured so… I don’t know exactly. I can do everything but open them by my trusted library.
I could just open all the files and then print them again as PDF to have an unsecured PDF file. But as I have lots of statements, this doesn’t sound too fun.
Of course there are also many paid softwares to remove PDF passwords and security features. Most cost once to register, some even monthly. Meh.
But if you spend some more time googling, there are also FREE tools:
- Weeny Free PDF Password Remover (Windows)
- QPDF (CLI)
Weeny’s tool is really nice and super usable. Happy ‚customer‘ here 🙂
Managing Twitter Lists
Published 2013-11-09, 22:37
I started to group my „twitter users I follow“ (Why is there no better word?) in (public and private) thematic lists to be able to follow them seperately. List management in Twitter’s web and mobile apps lacks a lot of features, so I went to trusted Google to find what is out there. Here are my 3 recommentations:
- http://twitlistmanager.com – Super easy list of users I follow and checkboxes for all lists I have. Saved in batches.
- http://icotile.ogaoga.org – Drag and drop with the twitter avatar makes it easy to spot people that don’t belong in a list. Saves every change indicidually.
- http://tweetbe.at – Theoretically more powerful than the other two because of automation options, practically a bit broken though 🙁 I still include it here, because it is what I actually want to have.
With these tools I was able to move some people around and dramatically clean up my lists.
Now to find (or create) a Twitter client that is made for lists and this style of reading. (On Windows, I recommend Tweetdeck.)
MySQL: Delete a subset in a table quickly
Published 2009-06-21, 14:04
Heute mal wieder über einen netten MySQL-Hack gestolpert:
The trick is, that INNER JOIN will ’shrink‘ the LargeTable down to the size of the TemporarySmallTable and the delete will operate on that smaller set only, since USING will reference to the joined table.
http://blog.mkoebele.de/2008/07/mysql-delete-subset-in-table-quickly.html
http://dev.mysql.com/doc/refman/5.0/en/delete.html#c9536
Mehr davon bitte…