2013-06-11 11:27:04 +00:00
|
|
|
There are two TODO lists. This file (good for airplanes) and the online bug tracker:
|
|
|
|
|
2018-01-06 03:49:59 +00:00
|
|
|
https://github.com/perkeep/perkeep/issues
|
2013-06-11 11:27:04 +00:00
|
|
|
|
|
|
|
Offline list:
|
|
|
|
|
2014-12-21 17:58:06 +00:00
|
|
|
-- fix the presubmit's gofmt to be happy about emacs:
|
|
|
|
|
Rename import paths from camlistore.org to perkeep.org.
Part of the project renaming, issue #981.
After this, users will need to mv their $GOPATH/src/camlistore.org to
$GOPATH/src/perkeep.org. Sorry.
This doesn't yet rename the tools like camlistored, camput, camget,
camtool, etc.
Also, this only moves the lru package to internal. More will move to
internal later.
Also, this doesn't yet remove the "/pkg/" directory. That'll likely
happen later.
This updates some docs, but not all.
devcam test now passes again, even with Go 1.10 (which requires vet
checks are clean too). So a bunch of vet tests are fixed in this CL
too, and a bunch of other broken tests are now fixed (introduced from
the past week of merging the CL backlog).
Change-Id: If580db1691b5b99f8ed6195070789b1f44877dd4
2018-01-01 22:41:41 +00:00
|
|
|
go fmt perkeep.org/cmd... perkeep.org/dev... perkeep.org/misc... perkeep.org/pkg... perkeep.org/server...
|
2014-12-21 17:58:06 +00:00
|
|
|
stat pkg/blobserver/.#multistream_test.go: no such file or directory
|
|
|
|
exit status 2
|
|
|
|
make: *** [fmt] Error 1
|
|
|
|
|
2014-12-21 17:03:31 +00:00
|
|
|
|
2014-12-21 08:53:53 +00:00
|
|
|
-- add HTTP handler for blobstreamer. stream a tar file? where to put
|
|
|
|
continuation token? special file after each tar entry? special file
|
|
|
|
at the end? HTTP Trailers? (but nobody supports them)
|
|
|
|
|
2014-06-27 19:00:22 +00:00
|
|
|
-- reindexing:
|
|
|
|
* add streaming interface to localdisk? maybe, even though not ideal, but
|
2014-12-21 08:53:53 +00:00
|
|
|
really: migrate my personal instance from localdisk to blobpacked +
|
|
|
|
maybe diskpacked for loose blobs? start by migrating to blobpacked and
|
|
|
|
measuring size of loose.
|
|
|
|
* add blobserver.EnumerateAllUnsorted (which could use StreamBlobs
|
|
|
|
if available, else use EnumerateAll, else maybe even use a new
|
|
|
|
interface method that goes forever and can't resume at a point,
|
|
|
|
but can be canceled, and localdisk could implement that at least)
|
2014-06-27 19:00:22 +00:00
|
|
|
* add buffered sorted.KeyValue implementation: a memory one (of
|
|
|
|
configurable max size) in front of a real disk one. add a Flush method
|
|
|
|
to it. also Flush when memory gets big enough.
|
2014-12-21 08:53:53 +00:00
|
|
|
In progress: pkg/sorted/buffer
|
2014-06-27 19:00:22 +00:00
|
|
|
|
2014-03-19 00:35:14 +00:00
|
|
|
-- stop using the "cond" blob router storage type in genconfig, as
|
|
|
|
well as the /bs-and-index/ "replica" storage type, and just let the
|
|
|
|
index register its own AddReceiveHook like the sync handler
|
|
|
|
(pkg/server/sync.go). But whereas the sync handler only synchronously
|
|
|
|
_enqueues_ the blob to replicate, the indexer should synchronously
|
|
|
|
do the ReceiveBlob (ooo-reindex) on it too before returning.
|
|
|
|
But the sync handler, despite technically only synchronously-enqueueing
|
|
|
|
and being therefore async, is still very fast. It's likely the
|
|
|
|
sync handler will therefore send a ReceiveBlob to the indexer
|
|
|
|
at the ~same time the indexer is already indexing it. So the indexer
|
|
|
|
should have some dup/merge suppression, and not do double work.
|
|
|
|
singleflight should work. The loser should still consume the
|
|
|
|
source io.Reader body and reply with the same error value.
|
|
|
|
|
2014-03-18 17:38:49 +00:00
|
|
|
-- ditch the importer.Interrupt type and pass along a context.Context
|
|
|
|
instead, which has its Done channel for cancelation.
|
|
|
|
|
2014-03-18 17:08:53 +00:00
|
|
|
-- S3-only mode doesn't work with a local disk index (kvfile) because
|
|
|
|
there's no directory for us to put the kv in.
|
|
|
|
|
|
|
|
-- fault injection many more places with pkg/fault. maybe even in all
|
|
|
|
handlers automatically somehow?
|
|
|
|
|
|
|
|
-- sync handler's shard validation doesn't retry on error.
|
|
|
|
only reports the errors now.
|
|
|
|
|
2014-03-14 19:11:08 +00:00
|
|
|
-- export blobserver.checkHashReader and document it with
|
|
|
|
the blob.Fetcher docs.
|
|
|
|
|
2014-03-14 16:14:56 +00:00
|
|
|
-- "filestogether" handler, putting related blobs (e.g. files)
|
|
|
|
next to each other in bigger blobs / separate files, and recording
|
|
|
|
offsets of small blobs into bigger ones
|
|
|
|
|
2014-02-07 18:45:59 +00:00
|
|
|
-- diskpacked doesn't seem to sync its index quickly enough.
|
|
|
|
A new blob receieved + process exit + read in a new process
|
|
|
|
doesn't find that blob. kv bug? Seems to need an explicit Close.
|
|
|
|
This feels broken. Add tests & debug.
|
|
|
|
|
2014-02-05 02:48:16 +00:00
|
|
|
-- websocket upload protocol. different write & read on same socket,
|
|
|
|
as opposed to HTTP, to have multiple chunks in flight.
|
|
|
|
|
|
|
|
-- extension to blobserver upload protocol to minimize fsyncs: maybe a
|
|
|
|
client can say "no rush" on a bunch of data blobs first (which
|
|
|
|
still don't get acked back over websocket until they've been
|
|
|
|
fsynced), and then when the client uploads the schema/vivivy blob,
|
|
|
|
that websocket message won't have the "no rush" flag, calling the
|
|
|
|
optional blobserver.Storage method to fsync (in the case of
|
|
|
|
diskpacked/localdisk) and getting all the "uploaded" messages back
|
|
|
|
for the data chunks that were written-but-not-synced.
|
|
|
|
|
|
|
|
-- measure FUSE operations, latency, round-trips, performance.
|
|
|
|
see next item:
|
|
|
|
|
|
|
|
-- ... we probaby need a "describe all chunks in file" HTTP handler.
|
|
|
|
then FUSE (when it sees sequential access) can say "what's the
|
|
|
|
list of all chunks in this file?" and then fetch them all at once.
|
|
|
|
see next item:
|
|
|
|
|
|
|
|
-- ... HTTP handler to get multiple blobs at once. multi-download
|
|
|
|
in multipart/mime body. we have this for stat and upload, but
|
|
|
|
not download.
|
|
|
|
|
|
|
|
-- ... if we do blob fetching over websocket too, then we can support
|
|
|
|
cancellation of blob requests. Then we can combine the previous
|
|
|
|
two items: FUSE client can ask the server, over websockets, for a
|
|
|
|
list of all chunks, and to also start streaming them all. assume a
|
|
|
|
high-latency (but acceptable bandwidth) link. the chunks are
|
|
|
|
already in flight, but some might be redundant. once the client figures
|
|
|
|
out some might be redundant, it can issue "stop send" messages over
|
|
|
|
that websocket connection to prevent dups. this should work on
|
|
|
|
both "files" and "bytes" types.
|
|
|
|
|
2014-01-31 11:55:05 +00:00
|
|
|
-- cacher: configurable policy on max cache size. clean oldest
|
|
|
|
things (consider mtime+atime) to get back under max cache size.
|
|
|
|
maybe prefer keeping small things (metadata blobs) too,
|
|
|
|
and only delete large data chunks.
|
|
|
|
|
2013-12-16 04:58:53 +00:00
|
|
|
-- UI: video, at least thumbnailing (use external program,
|
|
|
|
like VLC or whatever nautilus uses?)
|
|
|
|
|
2013-12-14 20:05:51 +00:00
|
|
|
-- rename server.ImageHandler to ThumbnailRequest or something? It's
|
|
|
|
not really a Handler in the normal sense. It's not built once and
|
|
|
|
called repeatedly; it's built for every ServeHTTP request.
|
|
|
|
|
2013-12-14 17:37:56 +00:00
|
|
|
-- unexport more stuff from pkg/server. Cache, etc.
|
2013-12-14 14:16:21 +00:00
|
|
|
|
2013-12-04 08:39:09 +00:00
|
|
|
-- look into garbage from openpgp signing
|
|
|
|
|
2013-12-04 05:36:58 +00:00
|
|
|
-- make leveldb memdb's iterator struct only 8 bytes, pointing to a recycled
|
|
|
|
object, and just nil out that pointer at EOF.
|
|
|
|
|
2013-11-10 00:55:49 +00:00
|
|
|
-- bring in the google glog package to third_party and use it in
|
|
|
|
places that want selective logging (e.g. pkg/index/receive.go)
|
|
|
|
|
2014-01-31 18:27:12 +00:00
|
|
|
-- (Mostly done) verify all ReceiveBlob calls and see which should be
|
2013-09-16 14:57:14 +00:00
|
|
|
blobserver.Receive instead, or ReceiveNoHash. git grep -E
|
|
|
|
"\.ReceiveBlob\(" And maybe ReceiveNoHash should go away and be
|
|
|
|
replaced with a "ReceiveString" method which combines the
|
|
|
|
blobref-from-string and ReceiveNoHash at once.
|
2013-08-21 20:57:28 +00:00
|
|
|
|
2013-08-04 02:54:30 +00:00
|
|
|
-- union storage target. sharder can be thought of a specialization
|
|
|
|
of union. sharder already unions, but has a hard-coded policy
|
|
|
|
of where to put new blobs. union could a library (used by sharder)
|
|
|
|
with a pluggable policy on that.
|
|
|
|
|
2018-01-08 03:57:49 +00:00
|
|
|
-- support for running pk-mount under camlistored. especially for OS X,
|
2013-07-07 22:30:55 +00:00
|
|
|
where the lifetime of the background daemon will be the same as the
|
|
|
|
user's login session.
|
|
|
|
|
2013-06-12 16:46:44 +00:00
|
|
|
-- website: add godoc for /server/camlistored (also without a "go get"
|
|
|
|
line)
|
|
|
|
|
2013-06-09 08:11:31 +00:00
|
|
|
-- tests for all cmd/* stuff, perhaps as part of some integration
|
|
|
|
tests.
|
|
|
|
|
2013-05-26 17:07:35 +00:00
|
|
|
-- move most of camput into a library, not a package main.
|
|
|
|
|
|
|
|
-- server cron support: full syncs, camput file backups, integrity
|
|
|
|
checks.
|
|
|
|
|
|
|
|
-- status in top right of UI: sync, crons. (in-progress, un-acked
|
|
|
|
problems)
|
|
|
|
|
2013-08-04 02:54:30 +00:00
|
|
|
-- finish metadata compaction on the encryption blobserver.Storage wrapper.
|
|
|
|
|
|
|
|
-- get security review on encryption wrapper. (agl?)
|
2013-01-21 22:52:49 +00:00
|
|
|
|
|
|
|
-- peer-to-peer server and blobserver target to store encrypted blobs
|
|
|
|
on stranger's hardrives. server will be open source so groups of
|
|
|
|
friends/family can run their own for small circles, or some company
|
|
|
|
could run a huge instance. spray encrypted backup chunks across
|
|
|
|
friends' machines, and have central server(s) present challenges to
|
|
|
|
the replicas to have them verify what they have and how big, and
|
|
|
|
also occasionally say what the SHA-1("challenge" + blob-data) is.
|
|
|
|
|
2013-01-21 00:28:00 +00:00
|
|
|
-- sharing: make camget work with permanode sets too, not just
|
|
|
|
"directory" and "file" things.
|
|
|
|
|
|
|
|
-- sharing: when hitting e.g. http://myserver/share/sha1-xxxxx, if
|
|
|
|
a web browser and not a smart client (Accept header? User-Agent?)
|
|
|
|
then redirect or render a cutesy gallery or file browser instead,
|
|
|
|
still with machine-readable data for slurping.
|
|
|
|
|
2013-01-20 23:58:34 +00:00
|
|
|
-- rethink the directory schema so it can a) represent directories
|
|
|
|
with millions of files (without making a >1MB or >16MB schema blob),
|
|
|
|
probably forming a tree, similar to files. but rather than rolling checksum,
|
2013-01-21 00:28:00 +00:00
|
|
|
just split lexically when nodes get too big.
|
2013-01-20 23:58:34 +00:00
|
|
|
|
2013-01-11 07:03:46 +00:00
|
|
|
-- delete mostly-obsolete camsigd. see big TODO in camsigd.go.
|
|
|
|
|
2013-01-09 03:43:09 +00:00
|
|
|
-- we used to be able live-edit js/css files in server/camlistored/ui when
|
|
|
|
running under the App Engine dev_appserver.py. That's now broken with my
|
|
|
|
latest efforts to revive it. The place to start looking is:
|
|
|
|
server/camlistored/ui/fileembed_appengine.go
|
|
|
|
|
2013-01-03 04:41:26 +00:00
|
|
|
-- should a "share" claim be not a claim but its own permanode, so it
|
|
|
|
can be rescinded? right now you can't really unshare a "haveref"
|
|
|
|
claim. or rather, TODO: verify we support "delete" claims to
|
|
|
|
delete any claim, and verify the share system and indexer all
|
|
|
|
support it. I think the indexer might, but not the share system.
|
|
|
|
Also TODO: "camput delete" or "rescind" subcommand.
|
2013-09-21 17:27:42 +00:00
|
|
|
Also TODO: document share claims in doc/schema/ and on website.
|
2013-01-03 04:41:26 +00:00
|
|
|
|
2013-01-03 04:37:37 +00:00
|
|
|
-- make the -transitive flag for "camput share -transitive" be a tri-state:
|
|
|
|
unset, true, false, and unset should then mean default to true for "file"
|
|
|
|
and "directory" schema blobs, and "false" for other things.
|
|
|
|
|
2012-12-24 17:59:52 +00:00
|
|
|
-- index: static directory recursive sizes: search: ask to see biggest directories?
|
|
|
|
|
|
|
|
-- index: index dates in filenames ("yyyy-mm-dd-Foo-Trip", "yyyy-mm blah", etc).
|
2012-12-07 01:57:27 +00:00
|
|
|
|
2013-01-20 21:40:09 +00:00
|
|
|
-- get webdav server working again, for mounting on Windows. This worked before Go 1
|
|
|
|
but bitrot when we moved pkg/fs to use the rsc/fuse.
|
2012-03-23 01:21:32 +00:00
|
|
|
|
2012-08-21 06:09:32 +00:00
|
|
|
-- BUG: osutil paths.go on OS X: should use Library everywhere instead of mix of
|
|
|
|
Library and ~/.camlistore?
|
|
|
|
|
2012-03-23 01:21:32 +00:00
|
|
|
OLD:
|
2010-11-05 04:17:22 +00:00
|
|
|
|
2014-01-31 18:27:12 +00:00
|
|
|
-- add CROS support? Access-Control-Allow-Origin: * + w/ OPTIONS
|
2011-03-06 21:22:58 +00:00
|
|
|
http://hacks.mozilla.org/2009/07/cross-site-xmlhttprequest-with-cors/
|
|
|
|
|
|
|
|
-- brackup integration, perhaps sans GPG? (requires Perl client?)
|
|
|
|
|
|
|
|
-- blobserver: clean up channel-closing consistency in blobserver interface
|
2011-06-13 15:49:29 +00:00
|
|
|
(most close, one doesn't. all should probably close)
|
2010-11-05 04:17:22 +00:00
|
|
|
|
2010-11-05 04:22:38 +00:00
|
|
|
Android:
|
|
|
|
|
2010-12-21 07:25:34 +00:00
|
|
|
[ ] Fix wake locks in UploadThread. need to hold CPU + WiFi whenever
|
|
|
|
something's enqueued at all and we're running. Move out of the Thread
|
|
|
|
that's uploading itself.
|
2010-11-05 04:22:38 +00:00
|
|
|
[ ] GPG signing of blobs (brad)
|
2010-12-19 23:29:42 +00:00
|
|
|
http://code.google.com/p/android-privacy-guard/
|
|
|
|
http://www.thialfihar.org/projects/apg/
|
|
|
|
(supports signing in code, but not an Intent?)
|
|
|
|
http://code.google.com/p/android-privacy-guard/wiki/UsingApgForDevelopment
|
2010-12-19 23:37:03 +00:00
|
|
|
... mailed the author.
|
|
|
|
|
2010-11-05 04:22:38 +00:00
|
|
|
Client libraries:
|
|
|
|
|
2013-01-20 23:10:15 +00:00
|
|
|
[X] Go
|
|
|
|
[X] JavaScript
|
2013-08-15 17:07:58 +00:00
|
|
|
[/] Python (Brett); but see https://github.com/tsileo/camlipy
|
2010-11-05 04:22:38 +00:00
|
|
|
[ ] Perl
|
|
|
|
[ ] Ruby
|
|
|
|
[ ] PHP
|