Subversion Repositories oidplus

Rev

Rev 446 | Rev 449 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 daniel-mar 1
 
239 daniel-mar 2
RECENT STUFF
412 daniel-mar 3
- At a lot of forms, if you press "enter", the "form" will not be submitted (e.g. "create ra" plugin), cannot reproduce?
355 daniel-mar 4
- Create a possibility to invoke cronjobs (VTS registration / automatic publishing) via crontab?
412 daniel-mar 5
- Publish RFC!
239 daniel-mar 6
 
448 daniel-mar 7
DESIGN / THEME PLUGINS:
8
- Add manifests and PHP main classes for the design plugin type
9
- Create a "Theme" plugin that combines "Colors" and "Design".
10
- Make a feature-interface to manipulate the CSS URL?
11
	Attention: JS function test_color_theme() has an hardcoded set of parameters and does not follow the arguments set in index.php!
12
- Add design plugins to the "Plugins" admin section
13
 
374 daniel-mar 14
IDEAS FOR NEW FUNCTIONALITIES
318 daniel-mar 15
- Admin plugin "Attachments" with following functionalities:
16
	* Show every object and its attachments, so that the admin knows what's going on
17
	  (Alternatively they can just look in the userdata directory using FTP)
18
	* Give the ability to enable/disable RA uploading/deleting
19
	  (Alternatively they need to do it in the configuration module and enter '0' and '1' by hand)
374 daniel-mar 20
- Make a plugin that shows warning from plugins (via "feature-interface"), e.g. the registration plugin could warn that CURL is not working correctly etc.
21
	But it should also have JavaScript components, e.g. check if dev/ and other confidential folders can be accessed (see code in setup/)
331 daniel-mar 22
- Excel/CSV import tool for bulk data import (as alternative to XML import. Maybe previous Excel->XML import tool?)
318 daniel-mar 23
 
432 daniel-mar 24
LDAP / OAUTH:
25
- Implement other OAuth providers?
26
- When someone is logged in using OAuth or LDAP, we must prohibit that the user changes their email address,
27
  because this would make him lose his account and OIDs, since the account is *NOT* linked to the OAuth/LDAP uid, but to the email address!!!
28
 
308 daniel-mar 29
TINYMCE
399 daniel-mar 30
- mce dirty flag: call performCloseQueryCB()/performCloseCB(), if ...
31
	OK:   The page (browser tab) is about to be closed or the page is reloaded
32
	      => TinyMCE uses the window.onbeforeunload event
33
	TODO: The browser navigation buttons are clicked
34
	      => This only works PARTIALLY. Preventing popstate() works and no data is lost,
35
	         but the browser will think that it was successful!!
36
	OK:   When a node at the jsTree is clicked (conditional select)
37
	OK:   In the openOidInPanel() function, i.e. when you enter something into the goto-bar.
38
- critical bug: open page, edit tiny mce, click save. Then F5 reload (not Ctrl+F5): then the old content is there again. Except if you press Ctrl+F5
39
	(cannot be reproduced anymore? tested with firefox and chrome)
402 daniel-mar 40
- TinyMCE "isDirty" does not correctly work on Internet Explorer: It always reports "dirty"
404 daniel-mar 41
	see bug https://github.com/tinymce/tinymce/issues/6048
399 daniel-mar 42
- The "is dirty" check should also include the "Title" input box
308 daniel-mar 43
 
239 daniel-mar 44
WHOIS
201 daniel-mar 45
- webwhois: beside TXT/XML/JSON more output modi?  CSV, S/MIME  (and add the S/MIME keypurpose to the X.509 certificates)
239 daniel-mar 46
- whois query 'oid:' should show all root entries (subordinate entries), but there is only the message "not found"
43 daniel-mar 47
 
292 daniel-mar 48
SETUP
157 daniel-mar 49
- There should be a "test database connection" button
50
 
314 daniel-mar 51
WEBSVN UPDATER
52
- implement support for external repos!!!
53
 
327 daniel-mar 54
DATA TRANSFER PLUGIN
55
- XML import: Let the user decide if existing OIDs shall be overwritten
56
- XML import: Let the user decide if RAs should be created
57
- XML import: Let the user decide if "created=now" should be set
58
- XML import: Waiting animation
59
- XML import: If output (errors) is too long, show them in a page rather than an alert() box
60
 
25 daniel-mar 61
SMALL THINGS
446 daniel-mar 62
- Should plugins be able to change the "Content-Security-Policy" header (i.e. to include external JavaScripts frameworks)
366 daniel-mar 63
- Copyright notice:
64
	* Currently, we have "2019", "2020" and "2019-2020". Change them all to "2019 - 2020"
65
	* Copyright <BY> Daniel Marschall ("by" is missing)
267 daniel-mar 66
- RA address data: Country selection box like in OIDInfo
407 daniel-mar 67
	Possible data source: https://datahub.io/core/country-list#resource-data
183 daniel-mar 68
- offer signature checker tool to verify WHOIS responses
351 daniel-mar 69
- minimum menu expansion level: make it configurable for all objects and plugins, e.g. so that when you open OIDplus, all OIDs till level 2 are expanded
183 daniel-mar 70
- Revive the idea of "information objects" = OIDs that contain content
153 daniel-mar 71
- API : Make a function that checks if a RA exists, and use it everywhere where needed
256 daniel-mar 72
- Object type plugins : take care that "treeicon.png" and "icon_big.png" exist everywhere (become standard)
122 daniel-mar 73
- freeoid: gmail app does not hyperlink the activation URL. why?
74
- how to avoid invite spamming?
382 daniel-mar 75
- when a PHP error happens (i.e. the AJAX script did not manage to output a JSON), the AJAX script outputs "Error: SyntaxError: Unexpected token < in JSON at position 0" ... better show the user the actual message, or something more user-friendly at least
109 daniel-mar 76
- when login expired, remove entries in the treeview
256 daniel-mar 77
- disable specific functions (e.g. invite, login, rainfo, forgot password) if the plugins are not installed (check if class type is registered using class_exists())
351 daniel-mar 78
- <abbr> in <code> is double underlined; that's not good
79
- if you have multiple identifiers, how do you tell the system which identifier should be the preferred one?
25 daniel-mar 80
- show whois links only if folder "whois/" exists
46 daniel-mar 81
- disable autocomplete on some forms
379 daniel-mar 82
- graphical improvements of forms (input edits aligned)
68 daniel-mar 83
- "Documents" section: Make documentation for usage of OIDplus (for members only)
74 daniel-mar 84
- admin config mehr user friendly, e.g. having the enable/disable object type stuff (like in registration wizard) also in the admin control panel
351 daniel-mar 85
- it would be good if after the login, the opened nodes in the tree would stay open
86
- html checkbox: make use of "label for"
88 daniel-mar 87
- when javascript fails, the form will be submitted to './' , that is not good! failed javascript must return false, so that the form does not get submitted
88
- admin: show privacy entries from RAs (but grey, so you know that it is private)
351 daniel-mar 89
- admin should be able to edit contact data of a foreign RA [XXX isn't that already implemented?]
90
- freeoid: hide asn.1 and iri columns, because the RA is not allocating these identifiers?
91
- .... maybe we should have a list of OIDs where the OID does not allocate ASN.1/IRI identifiers... then we can also make use of the OID-WHOIS attributes
379 daniel-mar 92
- Privacy flag of RAs: Should there be more privacy levels, e.g. that you don't show your personal name etc.?
351 daniel-mar 93
- You should be able to change the "created" date for an object! Or maybe hide it completely if you don't know the original creation date?
94
- In the CRUD table, you should be able to see the name of the OID? But on the other hand, the title is not in the control of the Superior RA, and the CRUD table is actually the allocation table of the Superior RA.
95
- natOrder() does only work for OID namespace!!! other sort mechanisms are necessary for other object types
88 daniel-mar 96
- jstree select: automatically scroll down
351 daniel-mar 97
- things like RA: show more things, address, email etc.
360 daniel-mar 98
- note that we (and the RFC) talk about Objects, but actually OIDs only reference objects, but they are not the objects
379 daniel-mar 99
- Should oid_utils.inc.php, xml_utils.inc.php, oidinfo_api, etc. all be put into 3p/ (especially if they have an own ViaThinkSoft repository)?
100
	Note that external SVN repos need to be "hard coded" into includes/oidplus.inc.php and update/index.php
101
- Multilang
102
	* Not yet translated:
103
		- includes\classes\http_class.class.php [Problem: This is a third-party code!]
104
		- includes\classes\phpsvnclient.class.php [Problem: This is a third-party code!]
105
		- plugins\publicPages\100_whois\whois\index.php [Problem: This page is kinda standalone and does not include the OIDplus code]
106
		- 3p\vts_fileformats\fileformats.conf [Problem: This is a third-party code!]
107
		- includes\classes\VtsBrowserDownload.class.php [Problem: This is a third-party code!]
108
	* Is there some useful German translation of the Apache 2.0 license?
382 daniel-mar 109
- WEID UUID: das UUID 2.25/GUID pendant zeigen als alternative id
412 daniel-mar 110
- When an OID is edited/added/deleted, don't reload the whole tree. Instead, just change the tree! This looks much more fluid.
2 daniel-mar 111
 
239 daniel-mar 112
DATABASE
264 daniel-mar 113
- SQLite3: Implement Natural OID sorting (natSort)
382 daniel-mar 114
- make usage of Foreign Keys
115
	PROBLEM: we need foreign keys with no check, because
116
	a) we want to keep log entries even if an object/user is deleted
117
	b) log_user.username can also be 'admin' (and therefore not be a foreign key to table 'ra')
118
	c) not every object should have a registered RA. There should be "unknown" RAs where only the email address is known
239 daniel-mar 119
 
25 daniel-mar 120
FUTURE
112 daniel-mar 121
- make use of Composer. Problems:
122
  * What if composer installs a version of a component, which is incompatible?
123
  * We need a new publishing script, because simply checking out SVN is not enough anymore. The user needs to execute composer. But what is if the user don't have composer (or dont have shell access at all?)
104 daniel-mar 124
- implement sitemaps xml
88 daniel-mar 125
- admin should be able to change wellknown oids?
2 daniel-mar 126
- move oid to different arc
351 daniel-mar 127
- for very large arcs (e.g. PEN): maybe you should not show everything in the tree select?
128
- support for ORS?
129
- "Cutting Edge Technologie": AJAX, JSON, completely UTF-8, CRUD frameworks, PDO, HTML5, Mobile Design, Pure CSS, Autoloading, Object Oriented (maybe not MVC, though), Testing, ...
64 daniel-mar 130
- "Search" plugin: Feature to search inside documentation (doc/ directory)
104 daniel-mar 131
- "Search" plugin: I want to search in all object types and RAs. Not first select the type.
88 daniel-mar 132
- How can we make sure that example objects are not exported using oid-info.com export?
133
- Administrator-Interface: enable and disable object types
161 daniel-mar 134
- detailled change-history of each oid
2 daniel-mar 135
 
115 daniel-mar 136
BUGS?
382 daniel-mar 137
- BUG! Ra ist logged in, dann wird sie gelöscht => die RA kann trotzdem die OIDs bearbeiten!
144 daniel-mar 138
- OIDplus does not work in Safari Mobile!
139
	1. You cannot scroll the OID grid, as the scrolling affects the whole page, not the grid.
140
	2. JQueryUI sliders cannot be dragged
115 daniel-mar 141
 
104 daniel-mar 142
REJECTED IDEAS
351 daniel-mar 143
- should there be more than one admin?
410 daniel-mar 144
- should there more than one person be able to manage an OID? (multiple emails per "RA" ?)
88 daniel-mar 145
- record first RA and current RA => X.660 does not have this requirement
146
- markers DRAFT, LEAF and FROZEN etc. => use "Protected" if you want to make it invisible
320 daniel-mar 147
- Giving the "goto" argument OIDs instead of names, so that there are no conflict
148
  with plugin vendors (like it was done with the "plugin" argument at ajax.php)
149
	Rejected due to following reasons:
150
	a) The "goto" parameter should usually be human readable (especially since it is shown at the right top)...
151
	   Having a ViaThinkSoft OID there might get the user confused because they could think that the
152
	   page is a OID page request for that OID instead of a plugin page.
153
	b) Vendors should use something like "?goto=oidplus:com.example...."
2 daniel-mar 154
 
433 daniel-mar 155
LOGS
156
- prune logs entries? automatically prune things like "logged in" but not prune OID changes, etc?
157
- admin logs: don't show all logs. load more log entries as soon as the page is scrolled down
158
- is it possible that LFI/RFI attacks fill the log files? This is not good!
159
- when user changed email from "A" => "B", then all previous log events for "A" are not visible for "B" anymore!
160
	=> should we also change the log entry email address references when the user changes their email address?
161
 
4 daniel-mar 162
IDEAS
426 daniel-mar 163
- Should object types be able to add additional sub-nodes/pages into the tree,
164
  which are not "real" objects?
165
  => currently OIDplusMenuUtils::tree_populate() handles the object tree loading
166
     ... but shouldn't this task do the plugin publicPages/000_objects ?
167
     ... then we could establish an API which can give object type plugins the possibility to add additional children
407 daniel-mar 168
- Host/Domain ObjectType?
169
- Hide/Proxy RA E-Mails from public requests
382 daniel-mar 170
- let users choose their own creation arc
171
- system guid (name based pubkey)?
368 daniel-mar 172
- In regards multilinguality: Allow "oidplus_base$dede.css", so that languages can have their own CSS (e.g. wider "Go" button)
173
	But this means that a language change also need to reload the style sheet (like the color-plugin does when you click "Test")
211 daniel-mar 174
- when a new oid is created, should we redirect to the newly created OID, so that the user can begin entering the description etc?
184 daniel-mar 175
- when an object was not found, the error message could show the next possible known object (like WebWHOIS does)
183 daniel-mar 176
- the "goto" quickbar (at the top right) could also be used to search something ...
177
- ... alternatively, the "object not found" error page could link to the search plugin
142 daniel-mar 178
- make color plugin available for everyone. Admin may permanently save the colors, but users should be able to set their own theme, saved via cookies
4 daniel-mar 179
- there should be a form where an RA can request an invitation, even if the superior RA did not invite them.
180
  the fact that a RA exists in the Object Table should permit the RA to invite theirself.
13 daniel-mar 181
- make a list of OIDs that do not assign ASN1/IRI identifiers (e.g. IANA PEN or ViaThinkSoft FreeOID), then reject any identifier the user provides
26 daniel-mar 182
- sanitize IPv4, IPv6, GUID during creation
183
	bei IPv4 und IPv6: - if it is a single host address, don't put /32 or /128 suffix
184
	                   - strike unnecessary bits that are not defined in the netmask (also at the whois output)
144 daniel-mar 185
- let the sysadmin decide if they want the title be "systemtitle - object title" or "object title - systemtitle"
186
- should a RA be able to mark their own oid as confidential, instead of asking the superior RA?
351 daniel-mar 187
- should there be an OIDplus project page at oidplus.viathinksoft.com instead of a "naked" system?
165 daniel-mar 188
- vendor signature to plugins + viathinksoft signatures + "check" program if all signatures match
181 daniel-mar 189
- have a menu item (plugin) "latest updates" which lists OIDs that have been changed or added recently?
204 daniel-mar 190
- (unsure:) would it be good if the superior RA comment is shown in the object page itself?
385 daniel-mar 191
- Protect attachments with a password? (Information objects?)
397 daniel-mar 192
- IPv4/IPv6 plugin: Should we allow that private IPs are put into categories (e.g. phyical locations?)
4 daniel-mar 193
 
104 daniel-mar 194
QUESTIONS
4 daniel-mar 195
- should the collation be case sensitive or case insensitive? For Java package names, it should be case senstivie
351 daniel-mar 196
- use word "guid" or "uuid"?
61 daniel-mar 197
- should "OID updated" be split into two categories "updated by superior" (e.g. identifiers) and "updated by owner" (description etc)?
351 daniel-mar 198
- Don't renew "updated" field if you just click "Update" but didn't change anything (e.g. because you just wanted to send an invitation again)
63 daniel-mar 199
- "Documents" section: Can base of URLs/images inside the HTML be changed automatically?
4 daniel-mar 200
 
214 daniel-mar 201
PRIVACY:
215 daniel-mar 202
- bring back "3p/cookiecontent"? DM 28 May 2019: Removed CookieConsent temporarily, because it is placed at the beginning of the page and therefore ruins the Google index ...
203
	=> We might not need it, because cookies are only set during login, and at the login page itself, we already warn about cookies, in addition to the Privacy documentation
379 daniel-mar 204
- Cookie law:
205
	Download CookieConsent code into _3p folder, do not hotlink it
206
	we need to log all consents
207
	do we need an explicit consent at the login form?
208
	do we need a consent for the cookie SSL_CHECK?
214 daniel-mar 209
 
16 daniel-mar 210
GUID Management
211
- Leaf nodes (GUIDs) should show/edit the Title in the CRUD, so you dont have to click the GUID to see the title
351 daniel-mar 212
- weird bug: when i edit "guid:oidplus", then, after reload the treeview after the update, "guid:activedirectory" will be opened. somehow, the last opened node will be opened during the reload?!