Update/Rebuild with Browser
Overview¶
This page is only relevant when building with a browser.
For Mac, please see: Update/Rebuild with Mac
Time Estimate (click to open/close)
Build the Loop App
- 5 min: Check Apple account status
- Check if you need to renew certificates (once a year only)
- 5 min: Update version if a new one is available
- 5 min: Start the Build
- 1 hour: Wait for the build to complete and appear in the TestFlight app on your phone
- depends on GitHub, Apple and TestFlight
- 5 min: Install from TestFlight onto your phone
Once a Year Renew Certificate
- 5 min: Clear out expired certificates
- 5 min: Generate new certificates
One Time: Complete the information for the Digital Service Act Compliance
- This is a new requirement that must be completed one time
- See Digital Service Act Compliance for instructions
Page Summary (click to open/close)
The Loop app must be built at least every 90 days when you build with a browser - this is TestFlight requirement.
Most users will start at How to Update or Rebuild.
If your GitHub Personal Access Token
has expired, we recommend you update it with No Expiration
as explained at GitHub Token.
If you are running Loop-dev
, be sure to review these instructions but modify for the branch you are using: refer to Build Loop dev with Browser
FAQs (click to open/close)
- "What is an update?" Anytime you want to change versions or if your TestFlight build is about to expire, follow the instructions on this page.
- "Do I delete my old Loop app first?" Definitely not! If you keep your Loop app on your phone, your Loop settings (and existing pod) will continue to work the same after the update. Seamless.
- "Do I need to start a new pod when I update?" No. Your existing pod session will continue seamlessly if you are using the same Developer Account as the last time you built.
- "What if I'm using a new/different developer account?" If you aren't building with the same developer account used when your existing app was built, then you will be installing a brand new (second) Loop app on your phone. Your existing pod won't work with the new app, so you might want to time this transition when you are due to change pods. Delete the old app once you get the new one all set up.
- Do I need a computer? No.
- Can I do this on my phone? Yes, especially after you update your GitHub token to
No Expiration
. - Did the directions change? Yes. We now recommend you select a GitHub Personal Access Token that never expires and supports automatic update and rebuild when that feature is released. It simplifies the build every 90-day process significantly.
- How do I set my GitHub
Personal Access Token
to never expire and to support the automatic rebuild feature? See this section Regenerate Token. - What happens to my existing builds when I change my GitHub Personal Access Token? Nothing. The
GH_PAT
only affect future builds. Previous build are available for the full 90 days. - Is there anything I have to do once a year? Yes. Once a year you need to get a new
Distribution Certificate
. These only last one year. See this section Renew Certificate
When to Update or Rebuild¶
Under ordinary circumstances, you do not have to rebuild or update your Loop app until TestFlight forces you to (90 days). However, there is no harm in building more frequently.
- You control when the new app is installed on your phone, refer to: Install on Phone: Disable Automatic Install from TestFlight
- You always want a build available in the TestFlight app
- You can use TestFlight to quickly install the app if you loose or break your phone and need to replace it
- You can use TestFlight to quickly install the app if someone accidentally deletes the app from your phone
How to Update or Rebuild¶
Summary of Update Steps
- Accept Agreements
- Renew Certificate (once a year)
- Update
Fork
- Build the Loop App
- Wait for TestFlight
- Install on Phone
Ignore the email that says you need to fix "issues" in your app. You are not selling the app in the app store; so no action is required. The app you built is for personal use for you or a family member.
There is also a helpful video for updating (it does not include the Renew Certificates step, which is only done once a year):
Accept Agreements¶
This is Step 1 of 6 - it may not always be necessary, but please check every time.
Sign in to your Apple Developer account. If there are agreements you have not accepted, you will get errors when you try to Build that indicate your Apple Secrets
are incorrect - that is very unlikely. You may also need to update your credit card information if it has changed, for example, if there is a new expiration date.
- For an update, you do not need to modify the
FASTLANE_ISSUER_ID
,FASTLANE_KEY_ID
orFASTLANE_KEY
- Check your Apple Developer account for agreements, then continue
If you need detailed instructions, click on this Apple Program License Agreement
Help Page.
- Accept the
Apple Program License Agreement
(only)- You do NOT need to accept anything related to the
Paid Applications Schedule Agreement
- You do not need to provide banking or tax information
- That is only required when you sell an app through the
App Store
- You do NOT need to accept anything related to the
Digital Service Act Compliance
- Configure yourself as a non-trader
- This is a new requirement that must be completed one time
- See Digital Service Act Compliance for instructions
Wait After You Agree
It typically takes 15 minutes before your updated agreement is available so you can complete your build.
If your build with browser fails, wait longer. An hour wait was reported by one person.
Renew Certificate¶
This is Step 2 of 6 - it is only needed once a year - you should get an email from Apple 30 days before your
Distribution Certificate
expires. (Don't worry if you did not see the email.)
Apps in TestFlight are not affected when a certificate expires or is revoked.
- Apps installed on the phone continue to run
- Apps can be installed from TestFlight onto a phone up through the TestFlight expiration date
- You just cannot build a new app until a new Certificate is generated
Do you want to know more? (Click to open/close)
This is only a summary - please follow the detailed steps below carefully.
-
Delete all your
Distribution Certificates
. Apple only allows you to have 2 of these. So get rid of the old ones so you will be able to create a new one that will last a full year. (Step 1 below.) -
The Certificate in question is embedded in your
Match-Secrets repository
. In order to proceed, you need to remove the old certificate fromMatch-Secrets
. Later this will be automated and can be done without modifying yourMatch-Secrets repository
, but for now the easiest way to do that is to just delete thecerts/distribution
folder in your currentMatch-Secrets repository
. -
Finally, for every app that you build with this method, you need to run
Create Certificates
for that app. (Step 4 below.)
Manual Steps to Renew Your Distribution Certificate
¶
Delete and Create
Do not miss the final step in this section. After you delete certificates, you must run the Action for Create Certificates
before you can build an app again.
- Use this link to view your Apple Developer Certificates
- If your screen shows no Certificates and you see a message "Getting Started with Certificates", your certificate already expired and was removed by Apple; so skip ahead to Step 2: Navigate to your
Match-Secrets
Repository - Carefully examine the
Type
column - do not delete aDevelopment Certificate
- If you do not have any rows that say
Distribution Certificate
, your certificate already expired and was removed by Apple; so skip ahead to Step 2 - If your certificate has an expiration date several months in the future - you can wait and renew your certificate later; skip ahead to Update
Fork
- If you do not have any rows that say
- Click each row that has a
Distribution Certificate
and revoke it - You will get an email informing you the certificate was revoked
- If your screen shows no Certificates and you see a message "Getting Started with Certificates", your certificate already expired and was removed by Apple; so skip ahead to Step 2: Navigate to your
-
Navigate to your
Match-Secrets
Repository- You can do this several ways, but one method is demonstrated by the GIF below
- Open the URL for your GitHub account (address is
https://github.com/username
whereusername
is replaced by your GitHub username - Click on the Repositories Tab
- Select Match-Secrets
-
Delete the
certs/distribution
folder of yourMatch-Secrets
repository
using these instructions. The GIF below indicates the places to click with numbered red rectangles:- Frame 1: Click 1 on the folder called
certs/distribution
- Frame 2: Click 2 and 3 on the three dots in the upper right and then
Delete directory
- Frame 3: Click 4 and 5 on
Commit changes
in the upper right and then accept the suggested choice by clicking onCommit changes
in the lower right
Deleting the certs/distribution folder did not work for me
Some people reported trouble with this step. The other option is to delete and create a new
Match-Secrets
repository: see ResetMatch-Secrets
- Frame 1: Click 1 on the folder called
-
While still within your Github account, navigate to your fork of LoopWorkspace.
- You can do this several ways, but one method is demonstrated by the GIF below
- Click on your username and then
Repositories
and selectLoopWorkspace
- Once you are on your LoopWorkspace repository, click on the link below and follow the instructions provided to create your certificates.
- Run the
Action
:Create Certificates
Other Apps
If you build other apps using the build with browser method, they have just had their certificates revoked.
- The existing apps you installed from TestFlight continue working until their TestFlight expiration date
- You cannot build new versions of the app until you run
Create Certificates
for that app - To make sure you don't forget, go ahead and do that for all your other
repositories
now
Update Fork
¶
This is Step 3 of 6 - it may not always be necessary, but please check every time.
Open your GitHub account and select your LoopWorkspace repository
from your repositories list.
Up to Date or Behind¶
-
If your
fork
is up to date with LoopKit version, you will see the messageThis branch is up to date with LoopKit/LoopWorkspace:{branch}
- there is no need to build again unless your Loop app in TestFlight is about to expire - in which case, proceed to Build the Loop App -
If your
fork
shows a message such asThis branch is 3 commits behind LoopKit:main
and you want to update and build, then clickSync Fork
by tapping where the red rectangle is shown in the graphic below, then in the pop-up window, tap onUpdate branch
and if it succeeds, move on to Build the Loop App
Ahead and Behind¶
- If your
fork
shows a message such asThis branch is 3 commits behind LoopKit:main and 4 commits ahead of LoopKit:main
; you might need to manually resolve a conflict.- This can happen if you customized your build
- Sometimes GitHub lets you keep your customizations while updating the
fork
- The GIF below is an example for LoopFollow
- Frame 1 shows the repository is both ahead and behind
- Frame 2 shows the
Sync Fork
option was selected - Frame 3 shows that GitHub was able to merge the new branch with existing customization
- Tap on
Sync Fork
and thenUpdate branch
and if it succeeds, move on to Build the Loop App - Sometimes GitHub cannot figure out how to combine the incoming changes with the customizations, so you have to choose to
discard changes
; you can always customize again after the update
Building a different branch
Do I need to do anything special to build a different branch?
Yes: please follow instructions at Build Development Version
Build the Loop App¶
This is Step 4 of 6 - this is always required.
Refer to graphic below as you follow the steps to build the Loop app.
- Click on the
Actions
tab - Select the
4. Build Loop
workflow on the left- If using a mobile browser, be sure to use landscape mode to more closely match how GitHub looks on a computer.
- Look on the right and click
Run workflow
to see the dropdown - Click on the green
Run workflow
button in the dropdown - Wait ~25 min for the build to complete successfully
- It is then processed by Apple and sent to TestFlight (be patient)
What if the Build Fails¶
If a new release is announced at Current Release, look to see if there are instructions about extra steps required with the release. (The release after 3.2.3 will certainly have extra instructions.)
If you are using the dev branch, head over to Build Development Version for information.
Otherwise, head over to Errors with Browser.
Apple Email to Ignore¶
You can ignore an email from Apple that there are things you must fix in your app:
- There is no action you need to take - the developers will handle any updates that are required before it affects your ability to build the app
- Other warnings only address issues if you were selling the app in the app store, but it is for your own personal use
Wait for TestFlight¶
You'll receive an App Store Connect email confirming that the build has completed processing, and a TestFlight email confirming the new app is ready to test.
- If you get an email that the action failed, then return to your repository and look for Build Action error messages
- Click on the most recent Build job with the red x by it
- If the details show this message,
Could not install WWDR certificate
- This means Apple did not reply to GitHub as fast as GitHub expected
- Make sure your developer account is in good standing and that there are no agreements that need to be accepted
- Repeat the build (previous step)
Install the Loop app on the phone¶
This is Step 6 of 6 - once you finish this, you are done and your app will last 90 days.
Open the TestFlight app on the Loopers phone and install the most recent version of the Loop app. Most Loopers have automatic update disabled on their phones, so this is a manual process. Don't forget.
The updated Loop app will show up in your TestFlight app on the Looper's phone.
- Your new app will have "Expires in 90 days"
- There may be older builds that are still in TestFlight
- It takes time for the update to show up in the TestFlight app
- Wait for the one that expires in about 90 days
- You will also see a build number in parentheses, that number increments each build - don't worry about the number
Calendar Reminder
This is a good time to put a calendar reminder in your favorite app.
Set it up for a few days before the TestFlight app will expire.
Automatic Update Disabled¶
Option 1: If you chose to Disable Automatic Install from TestFlight, you control when to install the app on the phone.
- This is the recommended option
- Open TestFlight on your phone and click
Install
as shown in the GIF below - If you are building for a child, follow the TestFlight for a Child instructions again
Automatic Update Enabled¶
We strongly recommend you toggle off Automatic Updates to allow you to be in full control over when the app is updated. This is even more important if you're using automatic builds from GitHub for version 3.3 or later.
Option 2: If you chose to enable Automatic Updates from TestFlight for the Loop app, the updated build will be installed over your existing app as soon as it uploaded to TestFlight.
- In this case, when you look at the TestFlight app on your phone, the app should have installed automatically
- Refer to the GIF above, the message will say
Open
instead ofInstall
Choose Previous Build¶
If you are a typical user who just builds a single version for yourself or your child, you do not need to read this section.
This section provides detailed instructions if you want to choose a previous build to install on your phone. Typically, the most recent build is selected but there may be special cases:
- You are supporting multiple family members and may build different versions for each
- You want to test a different
branch
or set of customizations; you can install a previous build once you are done with the test
This section covers two topics.
- Optional: Add Test Details to the TestFlight build
- Select a Previous Build
Add Test Details¶
About half an hour after the build action completes, the new build will appear in the TestFlight screen at this link: App Store Connect / Apps
- Log in if needed
- Select your Loop app
- Click on the
TestFlight
tab to see a screen similar to the graphic below
Select the build to which you wish to add testing notes. When you tap on that icon, it opens a screen similar to that in the next graphic.
Click inside the box under Test Details. Insert the text you want to see on the phone before you install this version of the app. Tap the Save
button at upper right and then < iOS Builds
at upper left.
In this example, the branch and commit number are included followed by an indication that this version includes the customizations preferred by this person. Your test details can be as simple as "Use this for Charlie".
Commit Number
If your build includes customizations, your commit number will not match what the developer expects to see if you need to ask for help.
Use this section Customization and SHA-1 to determine the SHA-1 before customization.
Select a Previous Build¶
First open the TestFlight app on your phone and select the Loop app.
Near the bottom of the screen is a row labeled previous builds.
- Tap on the previous builds row
- The available builds are grouped by app version number, choose your desired version
- Typically you choose the most recent build for that version and click Install and then Open after installation completes
- All your settings should remain
The following graphic shows the view seen in the TestFlight app on the phone. By adding test details (as explained in the previous section), the desired build is clear. For most people - they will just use the most recent build. This procedure is useful for those who build often or who support multiple family members.
The Loop App Build Details¶
In the Loop app, once installed on your phone, tap on Settings -> Support -> Issue Report
. The graphic below shows an example of the Build Details included in the report.
- The
profileExpiration
listed here is irrelevant - the app expires when the TestFlight expiration indicates- Pro Tip: Add a calender reminder for your next build
- An app built with a browser displays a
sourceRoot
that starts with/Users/runner/work/LoopWorkspace
- The
buildDateString
is when the app was built and transferred to TestFlight, not when it was installed on your phone - You can use 90 days from this date, as well as the Expires in ## Days on the TestFlight app, to know when you need to rebuild
- The
GitHub Token¶
Your GitHub Personal Access Token
should be configured:
Never expire
repo, workflow
permission scope
If you are not logged in to GitHub and have not logged in recently, then you may see the authentication screen when doing the steps below.
Authenticate if requested by clicking on the green Send SMS
button or entering your password.
Once you are authenticated, you will have access to view your personal access token.
Modify Personal Access Token
¶
If your Personal Access Token
has not expired but does not have the correct permission, you should modify it. Do not regenerate it.
Click on the link to view your token and compare it to the graphic below.
The graphic above has a blue rectangle added to indicate where you should see your token. If yours does not look like this, click on the link (FastLane Access Token
) to open a new display. Watch the GIF below - there are 4 frames, the last one has the Update token button.
- Click on the link (
FastLane Access Token
) to open a new display - This example has no workflow or repo checks in it
- Add a check to the workflow box
- Scroll all the way to the bottom of the screen and click on the green
Update token
button
After you click on the Update token
button, your FastLane Access Token
should now show repo, workflow
and look like the earlier graphic above.
The only reason to regenerate a token is if it is set to expire. Do not do the next section unless you have to.
Regenerate Token¶
If your Personal Access Token
has expired or has an expiration date, you can regenerate the new one at any time.
Update new GH_PAT to Secrets
After you get your new token, immediately add it to your Secrets
for any app you build with this method. You don't have to rebuild the app, but it's a good idea to at least run Action 1. Validate Secrets
for each repository to make sure you did not make a mistake.
You can regenerate your GitHub Personal Access Token
at any time by clicking on the link below. (it will open in a new browser tab.)
The FastLane Access Token
is a clickable link.
After you click on FastLane Access Token
your screen should be similar to the graphic below.
Your existing TestFlight builds are fine
The yellow GitHub warning by the Regenerate Token
button is for new builds you make in the future.
Previous builds are still available in TestFlight and are not affected by this action.
Note - selecting the workflow
check box below is new. If yours does not show that selection, add it before you click on Regenerate token (red highlight in graphic below).
Click on Regenerate token (red highlight in previous graphic) to see screen similar to next graphic.
- Most Loopers will have classic personal access tokens
- If you are a developer who needs to use the fine-grained (by repository) option, that's fine
Be sure to change the Expiration from 30 days
to No Expiration
. When you select No Expiration
a GitHub warning appears. Click on the green Regenerate Token
button (red highlight in following graphic).
The next screen shows your new token. Copy the token using the copy icon and save it along with your other secret settings.
The next step is to update GH_PAT in your Secrets
. (If you build other apps with this method - update the GH_PAT for all of them right now - do not forget.)
Update Secrets
¶
This example is for updating GH_PAT in the Secrets
for your repository
, but the same method can be applied when changing any of the Secrets
.
Open the repository
for which you will update Secrets
. On the far right is a Settings selection. If you don't see Settings (if last item on row is Insights), then you are not on your fork
or you need to sign in to your GitHub account. You should see username/LoopWorkspace
with forked
from LoopKit/LoopWorkspace
underneath.
Refer to the GIF for help. There are 3 frames.
- Tap on Settings, then scroll down until you see
Secrets and variables
on the left side and click on the drop down indicator to displayActions
. - Keep scrolling on the same screen, past the
Action secrets / New repository secret
row, until you see the list of your currentSecrets
. - Click on the GH_PAT, tap on the pencil and enter the new token in the form. Click on Update Secret to complete the action.
Scroll all the way to the top of the screen and tap on your LoopWorkspace link. Then follow the How to Update or Rebuild instructions to start a new build.
Build Development Version¶
The information to build a development (dev
or any other branch) has been moved to a new page: Build dev with Browser