2011-07-22 19:17:57 +02:00
|
|
|
<?php
|
|
|
|
|
2012-03-14 00:21:04 +01:00
|
|
|
final class PhabricatorUserSSHKey extends PhabricatorUserDAO {
|
2011-07-22 19:17:57 +02:00
|
|
|
|
|
|
|
protected $userPHID;
|
|
|
|
protected $name;
|
|
|
|
protected $keyType;
|
|
|
|
protected $keyBody;
|
2012-03-10 03:06:39 +01:00
|
|
|
protected $keyHash;
|
2011-07-22 19:17:57 +02:00
|
|
|
protected $keyComment;
|
|
|
|
|
Generate expected schemata for User/People tables
Summary:
Ref T1191. Some notes here:
- Drops the old LDAP and OAuth info tables. These were migrated to the ExternalAccount table a very long time ago.
- Separates surplus/missing keys from other types of surplus/missing things. In the long run, my plan is to have only two notice levels:
- Error: something we can't fix (missing database, table, or column; overlong key).
- Warning: something we can fix (surplus anything, missing key, bad column type, bad key columns, bad uniqueness, bad collation or charset).
- For now, retaining three levels is helpful in generating all the expected scheamta.
Test Plan:
- Saw ~200 issues resolve, leaving ~1,300.
- Grepped for removed tables.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T1191
Differential Revision: https://secure.phabricator.com/D10580
2014-10-01 16:36:47 +02:00
|
|
|
public function getConfiguration() {
|
|
|
|
return array(
|
|
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
|
|
'keyHash' => 'bytes32',
|
|
|
|
'keyComment' => 'text255?',
|
2014-10-01 16:59:44 +02:00
|
|
|
|
|
|
|
// T6203/NULLABILITY
|
|
|
|
// These seem like they should not be nullable.
|
|
|
|
'name' => 'text255?',
|
|
|
|
'keyType' => 'text255?',
|
|
|
|
'keyBody' => 'text?',
|
Generate expected schemata for User/People tables
Summary:
Ref T1191. Some notes here:
- Drops the old LDAP and OAuth info tables. These were migrated to the ExternalAccount table a very long time ago.
- Separates surplus/missing keys from other types of surplus/missing things. In the long run, my plan is to have only two notice levels:
- Error: something we can't fix (missing database, table, or column; overlong key).
- Warning: something we can fix (surplus anything, missing key, bad column type, bad key columns, bad uniqueness, bad collation or charset).
- For now, retaining three levels is helpful in generating all the expected scheamta.
Test Plan:
- Saw ~200 issues resolve, leaving ~1,300.
- Grepped for removed tables.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T1191
Differential Revision: https://secure.phabricator.com/D10580
2014-10-01 16:36:47 +02:00
|
|
|
),
|
|
|
|
self::CONFIG_KEY_SCHEMA => array(
|
|
|
|
'userPHID' => array(
|
|
|
|
'columns' => array('userPHID'),
|
|
|
|
),
|
|
|
|
'keyHash' => array(
|
|
|
|
'columns' => array('keyHash'),
|
|
|
|
'unique' => true,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
) + parent::getConfiguration();
|
|
|
|
}
|
|
|
|
|
2011-07-22 19:17:57 +02:00
|
|
|
public function getEntireKey() {
|
|
|
|
$parts = array(
|
|
|
|
$this->getKeyType(),
|
|
|
|
$this->getKeyBody(),
|
|
|
|
$this->getKeyComment(),
|
|
|
|
);
|
|
|
|
return trim(implode(' ', $parts));
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|