]> source.dussan.org Git - nextcloud-server.git/commitdiff
Handle corrupted scope values 25973/head
authorDaniel Calviño Sánchez <danxuliu@gmail.com>
Mon, 1 Feb 2021 03:32:28 +0000 (04:32 +0100)
committerDaniel Calviño Sánchez <danxuliu@gmail.com>
Fri, 23 Apr 2021 14:53:58 +0000 (16:53 +0200)
Due to a bug (fixed some commits ago) in the UsersController of the
settings app the scope of the properties can be null (for example, if
lookup server upload was disabled and the user then changed the display
name in the profile information). In that case now the scope menu icon
shows an error to inform the user.

The scope value will not change when other properties are modified until
the user chooses an explicit value from the menu. Note that until a
scope is explicitly set the property will behave as if it is private.

Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
apps/settings/js/federationsettingsview.js
apps/settings/templates/settings/personal/personal.info.php

index 9cefaf132f2abc411cd8605a0297b5defd0b5ab1..2476c3f942988e997821a351833f5076e36f9229 100644 (file)
                                if (!scopeOnly) {
                                        self._config.set(field, $('#' + field).val());
                                }
-                               self._config.set(field + 'Scope', $('#' + field + 'scope').val());
+                               // A scope could have been stored as null due to a previous bug.
+                               // Null values should be kept as such until the user explicitly
+                               // sets the right value, but they will be returned as empty
+                               // strings in the template (which would overwrite the null value
+                               // if sent). Due to this an extra class is needed to
+                               // differentiate them.
+                               var initialScopeValue = $('#' + field + 'scope').hasClass('corrupted-scope-value') ? undefined : $('#' + field + 'scope').val();
+                               self._config.set(field + 'Scope', initialScopeValue);
 
                                // Set inputs whenever model values change
                                if (!scopeOnly) {
                                        $icon.addClass('icon-link');
                                        $icon.removeClass('hidden');
                                        break;
+                               case '':
+                               case null:
+                               case undefined:
+                                       $icon.addClass('icon-error');
+                                       $icon.removeClass('hidden');
+                                       break;
                        }
                }
        });
index 15244036111e666e2f59c2daab3c6770ff8d32b6..ea56b00bbd6ece98ab62e85fbdc577b079775295 100644 (file)
@@ -70,7 +70,7 @@ script('settings', [
                                        </div>
                                </div>
                                <span class="icon-checkmark hidden"></span>
-                               <input type="hidden" id="avatarscope" value="<?php p($_['avatarScope']) ?>">
+                               <input type="hidden" id="avatarscope" value="<?php p($_['avatarScope']) ?>"<?php if (is_null($_['avatarScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <div class="personal-settings-setting-box personal-settings-group-box section">
@@ -124,7 +124,7 @@ script('settings', [
                                <?php } ?>
                                <span class="icon-checkmark hidden"></span>
                                <span class="icon-error hidden" ></span>
-                               <input type="hidden" id="displaynamescope" value="<?php p($_['displayNameScope']) ?>">
+                               <input type="hidden" id="displaynamescope" value="<?php p($_['displayNameScope']) ?>"<?php if (is_null($_['displayNameScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <div class="personal-settings-setting-box">
@@ -172,7 +172,7 @@ script('settings', [
                                <?php if ($_['displayNameChangeSupported']) { ?>
                                        <em><?php p($l->t('For password reset and notifications')); ?></em>
                                <?php } ?>
-                               <input type="hidden" id="emailscope" value="<?php p($_['emailScope']) ?>">
+                               <input type="hidden" id="emailscope" value="<?php p($_['emailScope']) ?>"<?php if (is_null($_['emailScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <?php if (!empty($_['phone']) || $_['lookupServerUploadEnabled']) { ?>
@@ -193,7 +193,7 @@ script('settings', [
                                           placeholder="<?php p($l->t('Your phone number')); ?>"
                                       autocomplete="on" autocapitalize="none" autocorrect="off" />
                                <span class="icon-checkmark hidden"></span>
-                               <input type="hidden" id="phonescope" value="<?php p($_['phoneScope']) ?>">
+                               <input type="hidden" id="phonescope" value="<?php p($_['phoneScope']) ?>"<?php if (is_null($_['phoneScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <?php } ?>
@@ -215,7 +215,7 @@ script('settings', [
                                           value="<?php p($_['address']) ?>"
                                           autocomplete="on" autocapitalize="none" autocorrect="off" />
                                <span class="icon-checkmark hidden"></span>
-                               <input type="hidden" id="addressscope" value="<?php p($_['addressScope']) ?>">
+                               <input type="hidden" id="addressscope" value="<?php p($_['addressScope']) ?>"<?php if (is_null($_['addressScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <?php } ?>
@@ -268,7 +268,7 @@ script('settings', [
                                        }  ?>
                                />
                                <span class="icon-checkmark hidden"></span>
-                               <input type="hidden" id="websitescope" value="<?php p($_['websiteScope']) ?>">
+                               <input type="hidden" id="websitescope" value="<?php p($_['websiteScope']) ?>"<?php if (is_null($_['websiteScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <?php } ?>
@@ -321,7 +321,7 @@ script('settings', [
                                        }  ?>
                                />
                                <span class="icon-checkmark hidden"></span>
-                               <input type="hidden" id="twitterscope" value="<?php p($_['twitterScope']) ?>">
+                               <input type="hidden" id="twitterscope" value="<?php p($_['twitterScope']) ?>"<?php if (is_null($_['twitterScope'])): ?> class="corrupted-scope-value"<?php endif ?>>
                        </form>
                </div>
                <?php } ?>