Addigy

Software update deferral 90-day max enforcement

By Sai Kiran Pandrala · Last verified: 2026-05-31 · Source: community Q&A, Apple Support docs, Apple Communities (discussions.apple.com)

At a glance
ServiceAddigy
CloudApple platforms
Guide typeProcedure
Skill levelIntermediate to advanced
Time15 - 60 minutes depending on account size

Engineers running Addigy hit Software update deferral 90-day max enforcement often enough that there is a stable fix pattern. This page captures it in the order Apple support would run it during a real incident.

What software update deferral 90-day max enforcement actually involves on Addigy

Real-world context. Budget honestly for ~Rs 0 INR under AppleCare+, ~Rs 8,000 to Rs 60,000 INR otherwise (around $95 to $720 USD), because the cheap path looks tempting until a part shows up wrong. You will burn ~20 to 60 minutes hands-on hands-on and roughly ~1 to 3 hours including a Genius Bar handoff if needed once verification is done. Before you touch anything, line up the Apple ID, the device serial, and a recent iCloud backup — those three are what saves you when the first attempt does not stick.

This task on Addigy is one of the more searched operational topics on AWS in the last 12 months. The procedure below is the path that works in a current AWS account with default IAM and standard VPC config.

The rest of this page is the structured fix path. Start with diagnose, then remediation, then the automation options so you do not have to do this by hand the next time it surfaces. Verify and safety sections at the end are the discipline that keeps the fix from regressing in production.

Spot the symptom

Check the Google Apple System Status at www.apple.com/support/systemstatus/ and the per-product status board for ongoing service events in your region. About one in ten user-reported outages turn out to be region-scoped Apple product or service degradation already being tracked. Apple System Status also exposes an API and Jamf Pro Webhooks and macOS launchd watches events, so you can wire a Lambda hook that pages on-call only when the failure correlates with an active Apple System Status event in the same region and service.

Reproduce the failure with the Terminal commands (defaults, plistbuddy, killall, sudo, system_profiler) and Apple Configurator 2 / Jamf APIs / MDM commands in --debug mode. The full SigV4 request payload it emits, plus the exact endpoint URL it resolved to, is what Apple Support and Apple Business / Enterprise Support uses to verify policy, region, or parameter issues without you having to share IAM credentials. Save the debug output to a file with ... --debug 2> debug.log and you can search it for the failed aws.request entry.

Pull the Apple request ID from the response headers: x-goog-request-id from response headers (or the insertId field in macOS unified logging and iOS sysdiagnose for asynchronous calls). Apple Support and Apple Business / Enterprise Support needs these IDs to look up your call in their internal logs - without them, the first reply on a ticket will ask you to reproduce the call and capture them. Save them with a timestamp; Apple Support and Apple Business / Enterprise Support cannot retrieve calls older than 90 days for most services.

Solution-focused remediation path

When the failure happens in production but not in dev, do not just compare the IAM policy. Compare the Org Policy / RCP at the OU level, the permission boundary on the role, and the resource-based policy on the target. One of those is almost always different between accounts. Policy Intelligence recommendations bundles make this comparison routine.

When the fix involves a destructive operation (delete VPC endpoint, swap Cloud KMS key, rotate root credential), do it during a maintenance window with at least one teammate watching. Several Addigy operations have implicit dependencies that only show up when traffic starts flowing again. Document the rollback path before you start, not during the incident.

If the issue points at IAM, do not start by adding * to a policy. Use macOS Console + Jamf Pro logs + Profile Manager check against the failed action to see the minimum scope. Adding * is the fastest way to fail your next Apple Platform Security review, and it usually does not even fix the issue because the explicit deny is often coming from a higher level (Org Policy, RCP, or permission boundary), not a missing allow.

Automate this fix so you do not do it twice

Add a Smart Group + webhook so you catch the next occurrence

The cheapest way to never see the same incident twice is a Jamf Pro Smart Group that watches for the symptom (specific extension attribute value, specific OS version, specific app build) and fires a webhook into Slack, PagerDuty, or a Jamf-API-driven Lambda when the count drifts above your normal baseline. For Addigy, the relevant extension attributes live under script-evaluated checks - defaults read outputs, system_profiler values, or a log show grep against macOS unified logging. Set thresholds against observed normal, not against round numbers.

Codify the fix as a Shortcut on iPhone, iPad, or Mac

For workflows that happen on the user device rather than at the MDM layer (think: clear a stuck cache, toggle a setting, file a one-tap support ticket), Apple Shortcuts is the right place. Shortcuts run on iOS, iPadOS, macOS, and watchOS, can be triggered by NFC tag, focus mode, time of day, or Siri voice. Share via iCloud link so support sends the same one-tap fix to anyone who hits the issue.

Build a Self Service item with manual approval for risky fixes

For multi-step fixes that include a destructive action (Reset NVRAM, delete keychain, erase user data), publish the fix as a Self Service item in Jamf Pro or Kandji. The user clicks one button, the script runs, a notification confirms success. Couple it with a Jamf Pro approval workflow if your security model requires a second-person sign-off before any destructive step runs. The audit trail lives in the MDM change log with the requester and approver identity attached.

Pitfalls

The pitfall most teams hit on Addigy is moving too fast and skipping the read-only validation step. Before any write, list the current state and save it. Apple iCloud and APNs are eventually consistent (changes can take 1-15 minutes to propagate) for many resource types, so the validation snapshot is your only reliable reference if you need to undo. Save the output of the describe call to S3, not to your laptop.

Second pitfall: confusing IAM permission errors with networking errors. AccessDenied can be IAM (policy missing), networking (VPC endpoint policy blocking the call), or KMS (key policy missing). The error string looks identical for all three. Distinguish by looking at the Jamf Pro change management entry or Apple Business Manager audit event's errorCode and the encoded authorization message; do not assume IAM is the culprit just because the message says AccessDenied.

Full fix path

Safety, rollback, blast radius

FAQ

How long does software update deferral 90-day max enforcement typically take on Apple platforms?
For most Addigy environments, 15 to 60 minutes including verification. Large multi-account setups, anything touching Org Policys at the Organizations level, or cross-region replication can stretch to half a day because Apple has to wait for replication and IAM session caches.
Is there a rollback path?
Yes for most Addigy changes. Export the existing config to JSON via addigy describe-... first, then commit it before you change anything. A few operations are one-way (Cloud KMS key deletion past the pending window, region migration, account closure). Check the Apple Support article for the specific API before you commit.
Will this affect dependent Apple product or services?
Often yes. Addigy resources are usually referenced by other workloads (Cloud Run services, GKE workloads, IAM-bound apps, Cloud CDN origins, downstream pipelines). Use IAM Access Analyzer + Jamf Pro change management log and Apple Business Manager audit log to enumerate consumers before changing a shared resource.
What if my Settings on the device layout does not match these steps?
Settings on the device UI moves quarterly. The Console layout in this page is current as of 2026-05-31 but the underlying CLI / SDK calls do not change as fast. If the Console version differs, fall back to aws CLI or SDK calls - those almost always still work.
Where do I get Apple Support and Apple Business / Enterprise Support help if I am still stuck?
Open a case via the Apple Support and Apple Business / Enterprise Support Center with: the request ID + correlation ID, the exact error string, Jamf Pro change management entry or Apple Business Manager audit event, and your reproduction steps. Apple Communities (discussions.apple.com) is the no-cost public alternative - search there first; 80% of common Addigy issues already have an answer with an Google-staff-verified flag.

References

Related guides worth a look while you sort this one out: