Good morning HN! John from Ghost here - Thanks for all your support over the last 5 years. We wouldn't be here if it wasn't for that very first blog post hitting the #1 spot of HN and getting so much attention back in 2012. That was the very first time anyone ever heard about Ghost, and everything we've built since then has been thanks to that.
I was looking to port over our homegrown django blog app into a proper blogging engine and I immediately though of Medium because of HN conditioning, and had so many problems with it, all of them boiling down to lack of control: No way to embed stuff we wanted (we wanted to embed interactive graphs and tooltips), no way to disable some bullshit features (highlight popups), no way to get our own domain name, etc.
Ghost solved all this. And on top of that, it's markdown, which makes it just fantastic. And open source. And self-hostable. And you guys run a wonderful, exemplary foundation behind it. I have nothing but admiration for what you do, and I'm proud to be a paying client for it and recommend it to anyone for company blogs (it is unfortunately expensive for personal stuff however).
My #1 wishlist for it is better image embedding/resizing/thumbnailing support (native image gallery & captions, native thumbnailing, automatic thumbnailing of hero headers for the article list view).
My #2 wishlist is Postgres support. I'm very sad you dropped support for it :(
> Developers regularly show up on Github, rage at us for something like not supporting Postgres - and then we say "ok so are you going to write and maintain Postgres support for Ghost?" and they say "of course not, I don't have time for that!" - and then occasionally they'll go on Twitter and tell all their followers to give us hell. As if organising a mob and shouting louder is the best way to get a bunch of people writing free code to do what you want.
Might be worth their while to consider using an ORM of some sort that supports PGSQL then? I know some don't like ORM's but for projects that are hosted in a diverse amount of setups / environments they make sense to me.
Whichever approach is fine, the end result is that less effort is made to directly support PGSQL in the long run, and you'd get to support any database back-end as a result. I only mention ORM's cause some have decent tooling (EntityFramework (Core), Diesel.rs, etc) which can be useful for generating schemas out of object models. Also in some cases ORMs are using DB abstraction libraries like for example Entity Framework is built on top of ADO .NET.
Hello John. You may want to clear up some of the language you use around open source and copyright. The blog post says "the entire product is open source and has no copyright." All open source licenses are enforced via copyright, and the license on the github repos that I spot checked are explicitly copyrighted with what appears to be the MIT license. I think the intent of the post is clear, but it currently doesn't line up with the source.
He also writes, “Anyone can do whatever they want with our code, for free.” The MIT license does allow one to do almost whatever one wants (e.g., sell a product based on a closed-source fork), so his statement may be consistent. Or it’s possible that he is actually disclaiming all copyright in the code. Or maybe he’s implying that he won’t go after license violators.
So, I guess I agree that his intent could be more clearly stated.
I've read many times from product creators that developers wildly overestimate the importance of choosing a language or technology stack when in fact it has little bearing on whether a product will succeed.
When it came to selecting Node, the biggest benefit was that it was notable. If we had said "HEY we're making another blogging platform in, wait for it, PHP!" -- it would likely have been significantly more difficult that the project would've been seen as noteworthy / attracted any users.
Conversely, Node is not without its drawbacks. The ecosystem is young today. It was positively infantile when we started. I don't even think there was a fully formed RSS library. In fact, from a technical point of view, most of what we've built would have been easier to achieve with other tools and frameworks.
Nowadays when we select technology, we tend to go for the oldest most reliable stuff we can find. The sort of stuff that when you have a problem and you google it, there are 5,000 people who have done it before. Because there are only SO many innovation battles you can fight simultaneously.
At one point we tried to rewrite our infrastructure using Docker/Swarm - it was a 9 month project which ultimately got completely cancelled at the last minute. Why? Turns out Docker Swarm doesn't scale above 500 instances and we needed to run about 10,000 for Ghost(Pro). We asked Docker Inc and their response was pretty much "idk lol". So now, especially with our infrastructure, we almost always select the most tried and tested technology. Boring stuff. Stuff that is very, very well understood.
The problem is, it's not cool to talk about how our infrastructure is built on very straightforward LXC containers, managed by HAProxy, connected to a cluster of MySQL servers. The tech isn't bleeding edge enough to hear about on HN, so you end up not hearing about it. But most of our best tech decisions end up being when we choose older technology.
Sorry, this got really long. Did Node.js influence our success? Yes! It made Ghost more popular and also more difficult to build. Would I change it? Definitely not.
> The problem is, it's not cool to talk about how our infrastructure is built on very straightforward LXC containers, managed by HAProxy, connected to a cluster of MySQL servers. The tech isn't bleeding edge enough to hear about on HN, so you end up not hearing about it.
And those are exactly the ones I want to hear about.
Like you I find the old, established tech choices to be good. New tech is fun to play with, but when I need to get work done and keep it running (for years) I take old every time.
Please write more on this!
Also, I like the interplay between new/risky tech in one area of your story and established in others. Pushing a manageable number of boundaries.
Woah! That information about Docker is bananas. I've worked on projects with more than 200 VMs. Talk about things that don't show up on HN: scaling issues with popular technology where you never find a solution.
Until fairly recently with docker enterprise, from what I've been able to gather Docker's official stance on Enterprise™-use has been "don't use docker, use runc, and build / orchestrate / etc it with kubernetes or something" which basically means "rewrite whatever you intend to use". (afaik this all changed with https://blog.docker.com/2018/04/announcing-docker-enterprise... )
Which is fine. "can execute binaries in isolation" and "can schedule rollouts and efficient disk/networking structures across many thousands of instances" are vastly different problems. Even "can deploy to 100s" and "can deploy to 1000s" are quite different, without something targeting 1k+ I wouldn't expect it to handle beyond a couple hundred without compounding issues.
Awesome! I love the combination of HAProxy and LXC containers. It's so great. And even better using Ubuntu's LXD(/LXC), with DNS service/auto discovery built-in. Eg, just reference myghost1.lxd in the haproxy backend config for the LXC target host.
Fantastic question. So the obvious answer is grow the company, right? That's pretty much what Amazon did for 20 years. Eschew profit in favour of reinvesting in building the company as big as possible. Not really our style, we'd rather keep the company small, but there's definitely still room to grow quite a lot from where we are now.
Beyond that point, we can spend money on anything which reasonably furthers the mission of the organisation - which has many aspects but the main ones in our case revolve around creation and education for journalism and open source software.
Some pipedream ideas we throw around from time to time:
- M&A (boring/obvious answer, but valuable)
- Create either grant-funding, or sensible investment funding (like indie.vc) for other open source projects and publishers.
- Create an independent media company, reporting on issues and stories we care about (running on Ghost)
- Buy some land and build a collaborative space for us and for others to work on open source, journalism and social good projects
Great work and writeup at Ghost. I bookmarked it as an example to give to others wanting to do business and good things at same time. Far as ideas for reinvestment, two things come to mind:
1. Build more tools that solve people's problems created by others vendors. As in, move sideways a bit diversifying your operation. Even better if the tools/apps complement each other where you can increase benefit per customer while cross-selling. Although not endorsing them (not a customer), Zoho seems like a good example of this where they keep developing additional products that might benefit their customers on top of their original ones. Enough FOSS-oriented non-profits doing that in enough sectors can stop a lot of lock-in and abusive practices over time via the alternatives they provide.
2. Invest in maintenance or security improvements of dependencies, esp libraries or infrastructure. These are often treated as externalities leading to a lot of problems we see like in report below . Ghost could deliver its good products/services on top of taking some responsibility for infrastructure it depends on. People buying Ghost get the immediate value plus knowledge they're supporting those things as well.
Just some ideas for you. Keep up the great work over there and good luck to you all! :)
Not part of Ghost, but as a general answer, it's always feasible to invest in anything that serves the mission.
Besides actually just reducing prices for services to not get profit, Ghost could create a foundation and give grants to any deserving work that serves the Ghost mission, such as supporting the FSF or EFF or funding other upstream or aligned stuff such as working to get more of their tools to be 100% free/libre/open…
I'm probably biased as I work on the admin interface day-to-day but technology-wise it's been great.
Upgrades are painless, typically requiring around an hour at most. If there are bigger framework changes we can usually upgrade immediately then clean up deprecations later as necessary but even then the work is normally minimal. When there are more stylistic changes that touch many files it's usually very quick work thanks to the codemods that are released alongside. All of this despite huge and continuous under-the-hood improvements in Ember since we've been using it.
Compared to what I've seen in other frameworks I think we've benefitted a lot in being able to spend pretty much zero time bike shedding which libraries will make up our core framework. We also save a lot of time not needing to upgrade disparate parts of a custom framework built of 3rd party libraries that aren't necessarily in sync with each other. The Ember addon ecosystem has also been stellar, with common solutions rallied around by the community such that they are usually as stable as core and kept up-to-date with the latest idioms without breaking backwards compatibility.
In conclusion Ember has allowed us to focus almost entirely on product rather than framework. It stays out of the way and provides very clear happy paths for typical workflows whilst allowing us to break out of those where needed without sacrificing any tooling or upgradability.
As for the downsides I think the biggest has been the limited pool of contributors. A lot of react bandwagon jumping has happened since we started with Ember and it's interesting when talking to other developers outside of the Ember ecosystem because there's a lot of historical and outdated views about what Ember is and isn't. The Ember core team and community is working hard to improve Ember's marketing message to counter that but it's tough to break through when the framework's core selling point is consistency through hype cycles.
I'd wager almost everyone who has used ember in production feels much the same way. Ember is basically the best js framework for most use cases but React won the marketing war and has the backing of FB, so Ember just got crushed. It's sad because I love using Ember but the limitation on opportunities is a career killer. At this point it's embrace React or die. I see companies moving to React simply because they can't hire for Ember, not because React is better in any way.
The company is based in Singapore, and the exact structure is a Company Limited by Guarantee with bylaws specifying mission. This is the standard entity for a non-profit entity which operates in a commercial space under British common law (also used in Singapore). It's pretty different to the US and not directly comparable to any structures there. Closest description to something in the US might be "A Benefit Corporation with no share capital"
Hi, I'm vaguely in the market for a new blogging platform, I went to ghost.org, hoping to get a sense for a sense of how it would feel to actually use ghost, but didn't find it easy to get that sense from the website. Do you perhaps have something like a test instance people can log into to try out, or a gallery of examples or somethng like that?
Just wanted to add my thanks here too. Started using Ghost (self hosted) for the developer blog for our SaaS about 3 years ago, and never looked back. Extremely easy to maintain and manage, and uses minimal server resources. Thanks for bringing Ghost into the world!
My most ever viewed medium post was about Ghost back when it launched. I remember talking one of my former customers (singlehop) into being one of the major tier investors in the kickstarter campaign. Nice to see you guys still around and kicking :-)
Essentially the same as you determine salary at any other company:
In the early days there's no structure, you just get on with it. As the company grows, generally a board of directors (or non-profit: board of trustees) act as an independent governance level for the org above the exec team and (amongst other things) determine executive pay.
There's an embedded podcast episode at the end of the post where Hannah and I discuss the remote team aspect in a bit more detail. Drop me a line on Twitter if there's anything specific you want to know - same username as here!
Since you're in the spotlight now, I want to bring back the discussion on image optimization . Looking at your Features page , there are 953KB of images that can be compressed down to 453KB (-47.3%). I genuinely wonder what you can save with better image optimization.
So, on a post which discusses problematic behaviour on Github where entitled people try to bully us into working on what they want without writing any code themselves -- you (someone who has tried to bully us before on Github) -- decide that being in the spotlight is a perfect time for you to draw everyone's attention to your feature request once more. Because you think bullying us with HN social pressure will help your cause.
And then, to back up your argument, you link to a page which is not running on Ghost - and actually does have optimised+responsive images.
All so you can spam your own image compression app.
> So, on a post which discusses problematic behaviour on Github where entitled people try to bully us into working on what they want without writing any code themselves -- you (someone who has tried to bully us before on Github) -- decide that being in the spotlight is a perfect time for you to draw everyone's attention to your feature request once more. Because you think bullying us with HN social pressure will help your cause.
This whole sentence is false. I did not "bully" you anywhere (!), requested a feature from you, or pressured you to do anything. Quite the opposite, I showed an easy way to improve. Again, I could have been wrong on the effect. That's why the question. The "spotlight" reference was just a small joke. Sorry.
> And then, to back up your argument, you link to a page which is not running on Ghost - and actually does have optimised+responsive images.
I meant only the Ghost homepage in the link, and better optimization (proves ).
> All so you can spam your own image compression app.
I gave you the facts. Yet, you smeared me with false accusations. Is this even fair?
We use hosted Ghost for our blog. For the most part, it's been great.
My biggest complaint is that Ghost doesn't yet have a built in SSL/TLS option (e.g. Let's Encrypt). Their recommendation is to use Cloudflare. It's fine for hobbyist or personal blogs, but as a corporation it's basically prevented us from using SSL.
We're in a regulated industry and need to do appropriate vetting of vendors. Onboarding a blog platform is very, very easy because of the relatively low risk nature of a blog. Onboarding an infrastructure vendor, like Cloudflare, is very complicated. Making it more complicated is we'd have no interest in actually paying for a Cloudflare service so it's impossible to get resources to complete the vetting process. On top of all of that, last year's Cloudbleed incident cast some real doubt on Cloudflare's security practices and ability to properly protect potentially sensitive data.
We will likely eventually self-host so we can get proper SSL support. I'm really disappointed by this since it will be more expensive than paying our Ghost subscription for several years.
For self-hosters, Ghost-CLI has deep Let's Encrypt integration. The tool will automatically guide you through provisioning an SSL certificate during the install process.
On Ghost(Pro) we have full end to end SSL support (you're right we used to only support CF's UniverSSL but that is no longer the case) - so anyone who uses a custom domain with Ghost(Pro) will automatically have an SSL cert provisioned and deployed for them in the background. For business customers who require the use of their own, custom certificates, there a few extra steps but we support that too.
Thanks for the post, its great to hear that Ghost is doing well - I love using it.
> [Github] has become too transactional - more support tool than collaboration
I strongly agree with this. I wish Github "Issues" were relabeled "Comments" and need not be "Open" or "Closed". Issues need action, comments do not. I've been burned many times now by solving someone's issue and then finding out they use my code for their business and just wanted free support from me.
You could create an issue template that explains the rules. If people still file support issues, you close those with a friendly reminder text (copy/paste) in which you explain the reasons why this is not the place for support. If people still think this is rude, they have personality issues which shouldn't be of your concern.
I'm not sure - in my experience I find that issues from new GH users are usually suspect (e.g. see ). So it might be nice to have something like the "Limit to existing users" , except not limited to a 24-hour period.
I wish GH users felt obligated to disclose they work for a company when creating issues that are for their company, but that's not something GH could (or should) enforce.
I was a Ghost user for ~3 years (from Jan 2014 to the best part of 2016) and eventually switched to WordPress. I loved Ghost minimalism and its usage of Markdown, but there were several issues that made it a no-no. I was kinda sad to let it go actually.
I took the time to write to the Ghost support email with my thoughts on the switch and my main issues (namely no categories, lack of i18n, editor live-view performance with many images, no search -- this was middle 2016, maybe they have these features now but they didn't then)
They took the trouble of answering my email, I found it rather nice.
I was a backer in the kickstarter campaign, but various "issues" eventually led me to look elsewhere.
Ghost is (was?) rather good, but the thing that ultimately sold me on it back on kickstarter was the much hyped dashboard, which never made it.
Before Docker it was a pain to manage dependencies and keep everything up to date, but with the official Docker image, things got better - until a flurry of almost daily releases to the 1.x branch made it a chore again.
The final nail in the coffin was dropping PostgreSQL support. While it wouldn't be much of an issue if starting on a clean host, with a clean slate, i run all of my other stuff in PostgreSQL, and i much prefer to only administer/backup one DMBS.
I'm currently on Hugo, and i really miss the online editing/publishing from Ghost.
I would love to switch to hosted ghost, but the pricing makes very little sense for a personal blog. An article will make the front page of hn or some larger subreddits and I'll get 30k views in just a few hours. I'd have to pay close to $200/mo to get the same number of page views I can get with a $10/VPS that I ssh into maybe once every 6 months to patch.
The pricing levels simply do not offer enough page views.
From the "unusually fair billing policy" section on the pricing page:
> Our plans are limited by how many readers you have, and how often they visit your publication. We only enforce these limits on a 3 month rolling average, so we'll never make you upgrade plans if you happen to have one big traffic spike or particularly successful month.
> The stuff which is actually hard, nobody ever asks about. For instance: How do you know when someone is in a bad mood? How do you deal with loneliness? How do you foster camaraderie? How do you achieve urgency? How do you ever get to know people outside of work when you never spend time with them outside of work?
I for one would love to hear more from the Ghost team on how they approach solving these very essential problems - any insight is welcome!
> We wanted to know: What would it look like if you built a technology startup which could not make anyone rich. If you eliminated all the promises of wealth from the roadmap up front, and tried to build a good company, how would that affect the product, business, customers, and every little decision in between?
> We're currently looking at testing an affiliate program whereby we'll pay out a 30% commission every single month on the lifetime revenue of anyone referred to Ghost(Pro).
I believe this is called colocating your money and your mouth. I'm inspired.
I’ve seen a couple comments about this issue, as well as it’s mention in the article. What about Postgres is appealing to the point that it is a deal breaker not to have? Is it familiarity or a specific aspect like scaling or ecosystem?
I prefer Postgres because of its (in my opinion: better) features and my familiarity with it. It wouldn't be a challenge to setup a MySQL/MariaDB database if I wasn't already running a largerish Postgres instance where I want to store my stuff. So the deal breaker here is me not wanting to have two DBMS running on the server.
> Our biggest marketing failure has been our documentation and resources. ... We're actually hiring right now for someone to help us fix this and make using Ghost a really fantastic developer experience.
Putting user docs as part of a marketing role is not lining things up for a good result. :(
Yes, user docs are customer-facing, but the problem is that if they're under the control of marketing, then documentation priorities will be set as if they are marketing materials. And, possibly worse, a writer who works in marketing will by and large be treated by engineers like, well, somebody who works in marketing. (Without getting into sordid details, I'm speaking from personal experience of having been a tech writer under engineering at one company and under marketing at another.)
That's cool, but we literally don't have a marketing department. So whoever gets hired will report directly to me, no matter what their title is.
The primary function of the role is to do writing, not engineering - and the success of the role will be measured in terms of marketing, not engineering - so to me the title we went with makes the most sense. I can definitely understand the discussion here though :)
it can work though - sometimes the evangelist role is under marketing (with lots of cross-pollination); customer success is usually under marketing. Think more post-sale support (keeping customers happy and increasing engagement) vs. sales. I wish more companies focused on marketing to existing, paying customers instead of just new wins. It's (a) easier and (b) has real, long term value over short-term metrics.
Without trying to offend… what's the quality of those commits?
I have a co-worker who commits 6x more changes than me, everyday, but only because she commits many errors in the morning and have to fix them during the day after multiple code reviews. She often forgets to run the test suite before pushing her changes up. Even after the creation of a Git hook to pre-test the changes after every commit, she still manages to break things when they fall outside the scope of the automated tests.
The number of commits mean nothing if the quality is low.
I've been rereading this article for days. Thanks so much for taking the time to share the sorts of insights that rarely see light.
My company is looking into our options as to what sort of structure would be best. We've considered being a worker-owned cooperative, a B Corporation, an a non-profit. We have the same goals of developing the best products we can an never selling out.
I wonder if you had any insight or suggestions on where to learn more about these options and the consequences. What do non-profits offer to funders? Everybody wants equity.
Same with Automattic, Zapier, Buffer - and most of the other big remote companies. In fact, we all use the same set of contracts. They tend to get passed around founders.
All 3 of those other companies are USA based, so for anyone in the US they do standard employment contracts - and anyone outside = self employed contractor on a retainer. We're based in Singapore and don't have any staff in Singapore, so effectively everyone is a remote self-employed contractor.
Our retainer contract looks a lot like an employment contract, practically speaking, and builds in all the same sorts of provisions as you would expect. We also cover expenses, where applicable, for team members to get independent legal and accounting advice to make sure everything is set up correctly for them.
Mr HashiCorp has gone way too far down the rabbit hole, by the sounds of it. It makes sense to set up a subsidiary when you have a larger group of staff in a single location. For instance, Automattic have a subsid in Ireland because they acquired a company there and as a result have a lot of staff based there. But otherwise it doesn't make sense to set up a full blown subsidiary in every country when you're a tiny startup just trying to contract a couple of people.
I signed up for ghost when it was at its kickstarter phase.
I was very excited by the promise. A year later there were still long winded discussions taking place on their github issues on how they should tackle responsive images.
There were alot of JS hacks around to overcome their missing features. I lost interest over time
I remember looking for better alternatives for WordPress(i felt they alienated the bloggers largely) and came across an article about Ghost. I was instantly hooked to the whole thing to this day. I just wish the non hosted versions get a better way to update to the latest version as well as a (official) script to automate the install easily.
When they launched ghost cli with ghost 1.0 I moved over to it a few days after it had launched (small blog, not much readership). It was really easy to move over to it, and updating ghost is a single command. I update it every time there's a feature I want or once every few months. It's not without its issues, but they're being actively worked on and it's improving each time I update the cli as well. I'd recommend it to anyone self hosting a single instance blog.
I didn't realize Ghost was a non-profit. Very noble. The feedback in Github is interesting. Ghost is probably more likely to have issues with demanding users than, say, mongodb.
Very cool and inspiring post. That said:
- Ghost's marketing materials tend to outright lie to users when making comparisons to WordPress or other platforms.
- I dislike OSS projects that hide their OSS nature. Why does a user need to pay $29/mo for an entry level blog? Why isn't there any obvious mention of the OSS nature of the project on the pricing page, home page, or features page?
- What's been done about the memory issues? Last time I tried ghost, it was a bit of a memory hog.
Homepage says it's FOSS, features page says it's FOSS, the developer page links to a giant Download button.
And how is it lying about their comparisons? It is indeed simpler to set up a Ghost site than a Wordpress site, and has more features out-of-the-box that you'd otherwise have to download sketchy plugins for with Wordpress/etc.
> It is indeed simpler to set up a Ghost site than a Wordpress site...
I...am not sure about that. WordPress, for all its warts, is exceedingly easy for even non-technical users to get up and running; that was a huge contributing factor to its rise. And a large part of that ease of use came from its choice of PHP and MySQL.
I know that in 2018 it's a lot easier to get non-PHP web apps up and running than it was in, say, 2008, but with the exception of hosting providers that have gone out of their way to set up "one-click installs" for Ghost like Digital Ocean, Node, Python, et. al, are still harder. This is something that John Nolan's post pretty explicitly acknowledged:
"We spent several years trying to engineer our way out of this in increasingly complex ways, so that people could set up a publication on Ghost with the same level of ease as they do on Medium. We never even got close. It's just not how modern web technology works."
(And, no, "just use a Docker container" is not a viable answer to give to anyone who doesn't already know what container technology is. Sorry.)
I imagine there's a difference between "managed hosting" (host handles OS/package updates and maintains your LAMP stack) and "managed WordPress hosting" (host handles all of the above AND core WordPress updates, basic security, etc).
Dreampress's non-shared hosting plans include "Wordpress Service Updates" which surely includes core Wordpress updates and updates to plugins they include, like Jetpack. It might also cover updating a list of the most popular plugins.
For security beyond running updated software, it includes a Wordpress-tuned web application firewall and the $24.95/month tier includes "Malware Scanning & Repair."
They didn't claim to not be a business in the blog post. They are a non-profit business. They still need to earn money to pay bill, pay employees, etc.
"Being a non-profit means that the company has no shares. I don't own it. Hannah doesn't own it. Nobody owns it - it's an independent entity. The company makes money and pays expenses, salaries and taxes as normal - but there's no way for it to be bought or sold either in part (investment) or as a whole (aquisition). Any profit the company makes can only ever be reinvested, not distributed. We can't cash out. Ever. Also the entire product is open source and has no copyright. Anyone can do whatever they want with our code, for free."
I really wish there was not so much damn confusion about what non-profit and not-for-profit actually mean. They do not mean that the organizations are some altruistic organizations with helper complexes. They simply don't report any profits because they either put it into expansion, inefficiency, or simply heap the profits upon their executives. So while you are heaping wishful and magic thinking good karma on non-profits, you don't realize a huge number of them, essentially far more of them than not, are more or less fraudulent organizations, especially on the federal and global level. While you donate to do good, their executives and officers live like Princes and Kings while they spend just enough to generate marketing and PR materials so the fools will keep giving and donating and volunteering and supporting their little schemes.
I know people don't want to believe that and it's a difficult thing to accept, which is why most people just cling to the "non-profit" label, but reality is realty, whether you accept it or not.
There is a place for this sort of cynicism, for example when looking at Zuckerberg’s structure of his “family trust.”
But in this case it’s really an absurd implication. There is literally no personal benefit to founders making their company a non-profit. Yes they can pull salary from it, but they could do that in a for-profit company too. Not only that, but it’s impossible to sell a 501c3 non-profit because there are no shares. It can only dissolve, in which case the board must distribute any remaining assets to another non-profit.
It’s absurd because if you sit down and do the math, you’ll find there are basically no monetary advantages to paying yourself out of a 501c3 vs LLC/SCorp/CCorp. And even if you did find an advantage, there is no way it saves more money than you could make by selling your company. You cannot sell a non profit.
You do have a point, but it’s a marginal gain at best. Unless you’re operating on razor thin profit margins, it’s not going to make a significant difference in how much you have available to pay yourself. And when you do pay yourself, you and the company need to pay taxes, even if the company is exempt from some income tax.
But really the important point is you cannot sell your company. How many years of 10% extra salary is worth sacrificing your ability to liquidate all the blood sweat and tears you put into your company?
the only advantage i could see in creating a non-profit vs a for-profit, specifically in this case, is that you get the free publicity and goodwill of customers at the start. "i'm creating a wordpress competitor" doesn't sound nearly as good as "i'm creating a wordpress competitor that can never be taken away from you because we are a non-profit". If you create a crappy product, it doesn't matter in the long run, of course.
Or one could just incorporate as a for-profit in the first place, and pay a $500k salary. There is basically no advantage to paying yourself $500k at a 501c3 vs a for-profit, and certainly not one that outweighs the many disadvantages. Employees need to pay taxes just as they would at any corporation, and the company needs to pay their withholdings. The only payroll tax a 501c3 is exempt from is FUTA (federal unemployment tax).
Seriously, looking for nefarious motivation here is really grasping at straws.
I also agree it feels like static site generators are starting to take over (personally think its an awesome direction the web is headed towards for some sites) but not everyone is familiar how to use them so Ghost is another nice alternative.
Unfortunately I think Github itself has a lot to do with this. The product has become too transactional - more support tool than collaboration. And Github themselves show remarkable disinterest in the open source community as a whole - they give us beta access to test new features every so often. That's about it. There's no wider involvement at all.
I read it as two parts. Interactions are flawed & Github doesn't really care about open source. Just one guys opinion, and my wife works for gitlab, but there is a deep commitment to open source and contributors, as well as an abundance of places for deeper dialogues to occur, between projects / contributors / the general public / gitlab.
+1 for also living in Minneapolis. We should get coffee.