Mrbytes
2012-12-19 e56a821d5ec9a2606f44f72dd24b7bf2f00e714d
src/com/gitblit/client/EditRepositoryDialog.java
@@ -24,6 +24,8 @@
import java.awt.Insets;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.ItemEvent;
import java.awt.event.ItemListener;
import java.awt.event.KeyEvent;
import java.text.MessageFormat;
import java.util.ArrayList;
@@ -37,6 +39,7 @@
import javax.swing.BoxLayout;
import javax.swing.ButtonGroup;
import javax.swing.DefaultComboBoxModel;
import javax.swing.DefaultListCellRenderer;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JCheckBox;
@@ -59,6 +62,8 @@
import com.gitblit.Constants.AccessRestrictionType;
import com.gitblit.Constants.AuthorizationControl;
import com.gitblit.Constants.FederationStrategy;
import com.gitblit.Constants.RegistrantType;
import com.gitblit.models.RegistrantAccessPermission;
import com.gitblit.models.RepositoryModel;
import com.gitblit.utils.ArrayUtils;
import com.gitblit.utils.StringUtils;
@@ -108,17 +113,25 @@
   
   private JCheckBox allowForks;
   private JCheckBox verifyCommitter;
   private JComboBox federationStrategy;
   private JComboBox ownerField;
   private JComboBox headRefField;
   private JComboBox gcPeriod;
   private JTextField gcThreshold;
   private JComboBox maxActivityCommits;
   private JPalette<String> usersPalette;
   private RegistrantPermissionsPanel usersPalette;
   private JPalette<String> setsPalette;
   private JPalette<String> teamsPalette;
   private RegistrantPermissionsPanel teamsPalette;
   
   private JPalette<String> indexedBranchesPalette;
@@ -186,6 +199,13 @@
               anRepository.availableRefs.toArray());
         headRefField.setSelectedItem(anRepository.HEAD);
      }
      Integer []  gcPeriods =  { 1, 2, 3, 4, 5, 7, 10, 14 };
      gcPeriod = new JComboBox(gcPeriods);
      gcPeriod.setSelectedItem(anRepository.gcPeriod);
      gcThreshold = new JTextField(8);
      gcThreshold.setText(anRepository.gcThreshold);
      ownerField = new JComboBox();
@@ -207,6 +227,9 @@
      isFrozen = new JCheckBox(Translation.get("gb.isFrozenDescription"),
            anRepository.isFrozen);
      maxActivityCommits = new JComboBox(new Integer [] { -1, 0, 25, 50, 75, 100, 150, 250, 500 });
      maxActivityCommits.setSelectedItem(anRepository.maxActivityCommits);
      mailingListsField = new JTextField(
            ArrayUtils.isEmpty(anRepository.mailingLists) ? ""
                  : StringUtils.flattenStrings(anRepository.mailingLists,
@@ -215,13 +238,41 @@
      accessRestriction = new JComboBox(AccessRestrictionType.values());
      accessRestriction.setRenderer(new AccessRestrictionRenderer());
      accessRestriction.setSelectedItem(anRepository.accessRestriction);
      accessRestriction.addItemListener(new ItemListener() {
         @Override
         public void itemStateChanged(ItemEvent e) {
            if (e.getStateChange() == ItemEvent.SELECTED) {
               AccessRestrictionType art = (AccessRestrictionType) accessRestriction.getSelectedItem();
               EditRepositoryDialog.this.setupAccessPermissions(art);
            }
         }
      });
      
      boolean authenticated = anRepository.authorizationControl != null 
            && AuthorizationControl.AUTHENTICATED.equals(anRepository.authorizationControl);
      allowAuthenticated = new JRadioButton(Translation.get("gb.allowAuthenticatedDescription"));
      allowAuthenticated.setSelected(authenticated);
      allowAuthenticated.addItemListener(new ItemListener() {
         @Override
         public void itemStateChanged(ItemEvent e) {
            if (e.getStateChange() == ItemEvent.SELECTED) {
               usersPalette.setEnabled(false);
               teamsPalette.setEnabled(false);
            }
         }
      });
      allowNamed = new JRadioButton(Translation.get("gb.allowNamedDescription"));
      allowNamed.setSelected(!authenticated);
      allowNamed.addItemListener(new ItemListener() {
         @Override
         public void itemStateChanged(ItemEvent e) {
            if (e.getStateChange() == ItemEvent.SELECTED) {
               usersPalette.setEnabled(true);
               teamsPalette.setEnabled(true);
            }
         }
      });
      
      ButtonGroup group = new ButtonGroup();
      group.add(allowAuthenticated);
@@ -231,7 +282,8 @@
      authorizationPanel.add(allowAuthenticated);
      authorizationPanel.add(allowNamed);
      
      allowForks = new JCheckBox(Translation.get("gb.allowForks"), anRepository.allowForks);
      allowForks = new JCheckBox(Translation.get("gb.allowForksDescription"), anRepository.allowForks);
      verifyCommitter = new JCheckBox(Translation.get("gb.verifyCommitterDescription"), anRepository.verifyCommitter);
      // federation strategies - remove ORIGIN choice if this repository has
      // no origin.
@@ -251,7 +303,8 @@
      fieldsPanel
            .add(newFieldPanel(Translation.get("gb.origin"), originField));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.headRef"), headRefField));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.owner"), ownerField));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.gcPeriod"), gcPeriod));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.gcThreshold"), gcThreshold));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.enableTickets"),
            useTickets));
@@ -266,6 +319,8 @@
                  skipSizeCalculation));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.skipSummaryMetrics"),
            skipSummaryMetrics));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.maxActivityCommits"),
            maxActivityCommits));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.mailingLists"),
            mailingListsField));
@@ -274,24 +329,31 @@
      .add(newFieldPanel(Translation.get("gb.isFrozen"), isFrozen));
      clonePushPanel
      .add(newFieldPanel(Translation.get("gb.allowForks"), allowForks));
      clonePushPanel
      .add(newFieldPanel(Translation.get("gb.verifyCommitter"), verifyCommitter));
      usersPalette = new JPalette<String>();
      JPanel northAccessPanel = new JPanel(new BorderLayout(5, 5));
      northAccessPanel.add(newFieldPanel(Translation.get("gb.accessRestriction"),
      usersPalette = new RegistrantPermissionsPanel(RegistrantType.USER);
      JPanel northFieldsPanel = new JPanel(new GridLayout(0, 1, 0, 5));
      northFieldsPanel.add(newFieldPanel(Translation.get("gb.owner"), ownerField));
      northFieldsPanel.add(newFieldPanel(Translation.get("gb.accessRestriction"),
            accessRestriction), BorderLayout.NORTH);
      JPanel northAccessPanel = new JPanel(new BorderLayout(5, 5));
      northAccessPanel.add(northFieldsPanel, BorderLayout.NORTH);
      northAccessPanel.add(newFieldPanel(Translation.get("gb.authorizationControl"),
            authorizationPanel), BorderLayout.CENTER);
      northAccessPanel.add(clonePushPanel, BorderLayout.SOUTH);
      JPanel accessPanel = new JPanel(new BorderLayout(5, 5));
      accessPanel.add(northAccessPanel, BorderLayout.NORTH);
      accessPanel.add(newFieldPanel(Translation.get("gb.permittedUsers"),
      accessPanel.add(newFieldPanel(Translation.get("gb.userPermissions"),
                  usersPalette), BorderLayout.CENTER);
      teamsPalette = new JPalette<String>();
      teamsPalette = new RegistrantPermissionsPanel(RegistrantType.TEAM);
      JPanel teamsPanel = new JPanel(new BorderLayout(5, 5));
      teamsPanel.add(
            newFieldPanel(Translation.get("gb.permittedTeams"),
            newFieldPanel(Translation.get("gb.teamPermissions"),
                  teamsPalette), BorderLayout.CENTER);
      setsPalette = new JPalette<String>();
@@ -342,6 +404,8 @@
      
      panel.addTab(Translation.get("gb.customFields"), customFieldsScrollPane);
      
      setupAccessPermissions(anRepository.accessRestriction);
      JButton createButton = new JButton(Translation.get("gb.save"));
      createButton.addActionListener(new ActionListener() {
@@ -396,6 +460,27 @@
      panel.add(fieldLabel);
      panel.add(comp);
      return panel;
   }
   private void setupAccessPermissions(AccessRestrictionType art) {
      if (AccessRestrictionType.NONE.equals(art)) {
         usersPalette.setEnabled(false);
         teamsPalette.setEnabled(false);
         allowAuthenticated.setEnabled(false);
         allowNamed.setEnabled(false);
         verifyCommitter.setEnabled(false);
      } else {
         allowAuthenticated.setEnabled(true);
         allowNamed.setEnabled(true);
         verifyCommitter.setEnabled(true);
         if (allowNamed.isSelected()) {
            usersPalette.setEnabled(true);
            teamsPalette.setEnabled(true);
         }
      }
   }
   private boolean validateFields() {
@@ -475,15 +560,19 @@
            : ownerField.getSelectedItem().toString();
      repository.HEAD = headRefField.getSelectedItem() == null ? null
            : headRefField.getSelectedItem().toString();
      repository.gcPeriod = (Integer) gcPeriod.getSelectedItem();
      repository.gcThreshold = gcThreshold.getText();
      repository.useTickets = useTickets.isSelected();
      repository.useDocs = useDocs.isSelected();
      repository.showRemoteBranches = showRemoteBranches.isSelected();
      repository.showReadme = showReadme.isSelected();
      repository.skipSizeCalculation = skipSizeCalculation.isSelected();
      repository.skipSummaryMetrics = skipSummaryMetrics.isSelected();
      repository.maxActivityCommits = (Integer) maxActivityCommits.getSelectedItem();
      
      repository.isFrozen = isFrozen.isSelected();
      repository.allowForks = allowForks.isSelected();
      repository.verifyCommitter = verifyCommitter.isSelected();
      String ml = mailingListsField.getText();
      if (!StringUtils.isEmpty(ml)) {
@@ -531,6 +620,7 @@
   
   public void setAccessRestriction(AccessRestrictionType restriction) {
      this.accessRestriction.setSelectedItem(restriction);
      setupAccessPermissions(restriction);
   }
   public void setAuthorizationControl(AuthorizationControl authorization) {
@@ -539,16 +629,16 @@
      this.allowNamed.setSelected(!authenticated);
   }
   public void setUsers(String owner, List<String> all, List<String> selected) {
   public void setUsers(String owner, List<String> all, List<RegistrantAccessPermission> permissions) {
      ownerField.setModel(new DefaultComboBoxModel(all.toArray()));
      if (!StringUtils.isEmpty(owner)) {
         ownerField.setSelectedItem(owner);
      }
      usersPalette.setObjects(all, selected);
      usersPalette.setObjects(all, permissions);
   }
   public void setTeams(List<String> all, List<String> selected) {
      teamsPalette.setObjects(all, selected);
   public void setTeams(List<String> all, List<RegistrantAccessPermission> permissions) {
      teamsPalette.setObjects(all, permissions);
   }
   public void setRepositories(List<RepositoryModel> repositories) {
@@ -601,12 +691,12 @@
      return repository;
   }
   public List<String> getPermittedUsers() {
      return usersPalette.getSelections();
   public List<RegistrantAccessPermission> getUserAccessPermissions() {
      return usersPalette.getPermissions();
   }
   public List<String> getPermittedTeams() {
      return teamsPalette.getSelections();
   public List<RegistrantAccessPermission> getTeamAccessPermissions() {
      return teamsPalette.getPermissions();
   }
   
   public void setCustomFields(RepositoryModel repository, Map<String, String> customFields) {
@@ -652,14 +742,15 @@
    * restriction.
    * 
    */
   private class AccessRestrictionRenderer extends JLabel implements
         ListCellRenderer {
   private class AccessRestrictionRenderer extends DefaultListCellRenderer {
      private static final long serialVersionUID = 1L;
      @Override
      public Component getListCellRendererComponent(JList list, Object value,
            int index, boolean isSelected, boolean cellHasFocus) {
         super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
         if (value instanceof AccessRestrictionType) {
            AccessRestrictionType restriction = (AccessRestrictionType) value;
            switch (restriction) {