Requirements
- PostgreSQL or MySQL server.
- Stripe account.
- Postmark account.
Step 1: Open the .NET solution
Open the NetcoreSaas.sln
solution with Rider or Visual Studio.
There are 3 environment files on the backend:
- appSettings.json: Production
- appSettings.Development.json: Development
- appSettings.Testing.json: Testing
And 2 environment files on the frontend:
- .env.production
- .env.development
Step 2: Find and Replace Environment Variables
You need to Find and Replace the following values.
IMPORTANT: Use the ‘Match case’ find and replace option:
data:image/s3,"s3://crabby-images/e2889/e288903c466c0b451faab238332bc3334071904d" alt="Match case"
- PRODUCT_URL: Your SaaS URL (without https:// or slashes).
- PRODUCT_NAME: Your SaaS name.
- SUPPORT_EMAIL: e.g. admin@saasfrontends.com.
- COMPANY_NAME: Legal incorporation name.
- COMPANY_ADDRESS: Incorporation address.
- POSTMARK_SERVER_TOKEN: An UUID, get it here.
- POSTMARK_SENDER_NAME: e.g. Alex, get it here.
- POSTMARK_SENDER_EMAIL: e.g. hello@saasfrontends.com, get it here.
- Development environment:
- DEVELOPMENT_DATABASE_NAME: e.g. dev-db.
- DEVELOPMENT_SERVER: e.g. localhost.
- DEVELOPMENT_PORT: e.g. 5432.
- DEVELOPMENT_USER: e.g. testing.
- DEVELOPMENT_PASSWORD: e.g. password123.
- DEVELOPMENT_STRIPE_PUBLIC_KEY: get it here.
- DEVELOPMENT_STRIPE_SECRET_KEY: get it here.
- DEVELOPMENT_ADMIN_EMAIL: e.g. admin@saasfrontends.com.
- DEVELOPMENT_ADMIN_PASSWORD: e.g. password123.
- Testing environment:
- TESTING_DATABASE_NAME: e.g. tests-db.
- TESTING_SERVER
- TESTING_PORT
- TESTING_USER
- TESTING_PASSWORD
- TESTING_STRIPE_PUBLIC_KEY: get it here.
- TESTING_STRIPE_SECRET_KEY: get it here.
- Production environment:
- PRODUCTION_DATABASE_NAME: e.g. prod-db.
- PRODUCTION_SERVER
- PRODUCTION_PORT
- PRODUCTION_USER
- PRODUCTION_PASSWORD
- PRODUCTION_STRIPE_PUBLIC_KEY: get it here.
- PRODUCTION_STRIPE_SECRET_KEY: get it here.
- PRODUCTION_ADMIN_EMAIL
- PRODUCTION_ADMIN_PASSWORD
For example, if my website will be saascourses.net, I’ll replace PRODUCT_URL (using Match case):
data:image/s3,"s3://crabby-images/f0de4/f0de4c0dec7282db7f59cd025539c9f1c29d13fc" alt="Find and Replace"
Frontend Service Mode
Since we’ll be running the backend, open the .env.development
file and set the …_APP_SERVICE variable to api.
Learn more about the Fake API feature.
# Options: api, sandbox
..._APP_SERVICE=api
...
Step 3: Database Migrations
On the terminal and run the following commands.
Note: By default, it will take the Development environment (appsettings.Development.json).cd src/NetcoreSaas.WebApi
dotnet ef migrations add Initial --context MasterDbContext
Expected output:
Build started...
Build succeeded.
Done. To undo this action, use 'ef migrations remove'
Then apply the migration to the database:
dotnet ef database update --context MasterDbContext
Since the Startup.cs class runs the migration twice (for multi-tenancy purposes), you can ignore the following error.
...
42P07: relation "AuditLogs" already exists
Verify that the database was created.
data:image/s3,"s3://crabby-images/61a2c/61a2cb807c6fe16d17e4f2c4c48bfe94729006b0" alt="Created database"
Step 4: Debug the app on Rider or VS
Select the NetcoreSaas.WebApi: NetcoreSaas configuration and Debug the app.
data:image/s3,"s3://crabby-images/86292/86292ad72c43e4b1e86021d08d0ec6942302b367" alt="Debug the app"
The Web API + Client app will launch at port 5000.
data:image/s3,"s3://crabby-images/ccbb8/ccbb8c0feb4713b3940d9c53e886cbb8d355c0e5" alt="App on port 5000"
Step 5: Run the Frontend on VS Code
For Vue2 projects:
npm install
npm run serve
For Vue3, React and Svelte projects:
npm install
npm run dev
And open http://localhost:8080.
data:image/s3,"s3://crabby-images/f2919/f29190a097048b21019eeb36c5ca82bc78d426aa" alt="App on port 8080"
Step 6: Set up your pricing
Pricing plans
Preview
Open the /pricing URL and take a look at the default pricing:
data:image/s3,"s3://crabby-images/a049b/a049b36c5c770fdca7c58ee60ae7b69d5b5335c0" alt="Default pricing"
The warning banner is just telling you that these prices are yet to be created on the Database and Stripe.
data:image/s3,"s3://crabby-images/c1648/c1648674951377af8eb7f7d33fea970b979c6a7f" alt="Warning - Prices not in Database"
Open the frontend src/application/plans.ts
file and update the prices as you see fit.
Save Pricing
Once you’re happy with your pricing, log in as your admin user (remember your DEVELOPMENT_ADMIN_EMAIL
and DEVELOPMENT_ADMIN_PASSWORD
values) and go to /admin/pricing.
data:image/s3,"s3://crabby-images/4951e/4951e2c26fc04114d1910f607f1a944dc4e657ff" alt="Admin | Pricing"
Click on the button “Click here to generate these prices in Database and your Subscription provider” and wait a few seconds.
Verify your Stripe Dashboard
Open the Stripe dashboard and verify that the subscription products were created.
data:image/s3,"s3://crabby-images/0560e/0560e1a7cb203076bb74026b4e24b2634f63e7b2" alt="Stripe products"
Verify your Database
Run an SQL query to verify that your products were persited to your database.
select * from "SubscriptionProducts";
data:image/s3,"s3://crabby-images/2540a/2540a62033717e2a0a12c62eb12581f913510b1d" alt="Database products"
Step 7: Set up Email Templates
Go to /admin/emails and take a look at the default templates:
data:image/s3,"s3://crabby-images/00ad5/00ad5fe6d717bea26a4379d6dcd0b7d48dab53f9" alt="Admin | Postmark email templates"
If you check your postmark server templates dashboard, it should be empty:
data:image/s3,"s3://crabby-images/d20f3/d20f3c7283064c880311741e917872ddaaed66e8" alt="Postmark email templates - Empty"
You can learn more about Postmark email templates here.
Creating the Postmark Templates
We need to create them by clicking on the “Create All” button and wait a few seconds.
Once the process is done, check your postmark server again, there should be 10 templates:
data:image/s3,"s3://crabby-images/73ed3/73ed3db41a11fefd2606071bbf53f0a592663f93" alt="Postmark email templates"
Step 8: Create an account
Register
Log out, go to the /pricing page and select a plan to register as a new user/tenant.
data:image/s3,"s3://crabby-images/5ccd9/5ccd97f684415e83a837530c1dcf8206e57e14f7" alt="Register"
As you can see, I’ve selected a paid (yearly) plan, so it will ask for my payment info:
data:image/s3,"s3://crabby-images/7c907/7c9075887477b5a45cbf1168143a4df5d6d963f1" alt="Payment info"
You can only use a testing card, learn more about it here, I’m using:
- Card number: 4242 4242 4242 4242.
- MM / YY: 04 / 24.
- CVC: 242.
- ZIP: 42424.
Dashboard
It should redirect you to the /app/dashboard:
data:image/s3,"s3://crabby-images/e296e/e296e750b570613f18491c1aa04e1243946f10e9" alt="Dashboard"
Welcome Email
Verify that you got the welcome email:
data:image/s3,"s3://crabby-images/5023a/5023a02c2567bf6f9b05af640b005cb32ad18e6a" alt="Welcome Email"
Stripe Payment
Verify that the payment is on your Stripe dashboard:
data:image/s3,"s3://crabby-images/5ca1c/5ca1cbaaa550bffce58c3a6ebdcf1bd3d992e221" alt="Stripe Payment"
Step 9: Test the App
Now we’re ready to test the sample app.
Employees
Create an employee by clicking the Employees sidebar item, and “Add employee” button:
data:image/s3,"s3://crabby-images/561e2/561e2f0a07d724c5198e0f458093277382d7584d" alt="Employees Sidebar Item"
data:image/s3,"s3://crabby-images/6b66f/6b66f07d4016d763cdec2488e2b3114f6a587b93" alt="Add Employee Button"
data:image/s3,"s3://crabby-images/ae9cf/ae9cf68f0fb552ada72ba72349e3a290c9e77669" alt="Add Employee"
It will redirect you to the employees list page:
data:image/s3,"s3://crabby-images/cc78b/cc78b512e68ed9b404c90de0b6ca5e6aaaef0bd6" alt="Employees List"
Verify that the Employee is created on the database:
select * from "Employees";
data:image/s3,"s3://crabby-images/4eec0/4eec0c495e860983f28cfff7183fd43682eafa78" alt="Employees Database"
Links
A Link is a core concept of SaasFrontends. It allow your users (tenants) to create links between them.
In this sample app, a Link consists of the Client and the Provider. Either of them can create a share a Contract with the other.
Invite a user as your Client
Click on the Plus button on the top right corner and Click on the “New Client” option.
data:image/s3,"s3://crabby-images/bbabc/bbabcf422684554a72f5636b1e56052db18d47a1" alt="App Plus Button"
Invite your ‘client’:
data:image/s3,"s3://crabby-images/02db8/02db8a9688c75463d9f6187b9ca7ffbc6e3db4b3" alt="New Client"
Check your inbox, you should get an invitation to join:
data:image/s3,"s3://crabby-images/4c662/4c66223a3cb676a0a2ef22cd1be95903fae6f8ce" alt="Invitation Email"
Click on the “Create account” button, it will redirect you to create an account. I’ll be selecting a Free plan.
data:image/s3,"s3://crabby-images/afe8a/afe8ada9e3f57064913fffd5818ee0b15fe1f5df" alt="Register as Client"
It should redirect you to the /app/dashboard. Log out, and Log in as the previously created user (on Step 8).
Verify the created Link
Click on the Links -> All sidebar item. There should your ‘client’.
data:image/s3,"s3://crabby-images/f2dbd/f2dbde67d06920f31c212c36510bfb224bdc5c68" alt="All Links"
Contracts
Click on New contract, and create a sample contract. Once created, it will redirect you to view the contract details:
data:image/s3,"s3://crabby-images/bc6bd/bc6bd560fbebf3a96cd179de66f9e4d9e23e0a14" alt="Contract Details"
Step 10: Integration Tests
Stop the application and go to the Unit Tests tab:
data:image/s3,"s3://crabby-images/5c430/5c4301dd3d2f3ae9538252d43681917a49df7d1f" alt="Unit Tests"
Right click on the “tests” folder and click “Run Selected Unit Tests”.
All 91 tests should pass:
data:image/s3,"s3://crabby-images/5ced0/5ced04dc6731cbe2bbd1a313fd0e0bdf7b471c03" alt="Unit Tests Passed"
—
Please let me know if you have any questions.