<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[13489] CalendarServer/trunk/calendarserver/tools</title>
</head>
<body>

<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://trac.calendarserver.org//changeset/13489">13489</a></dd>
<dt>Author</dt> <dd>cdaboo@apple.com</dd>
<dt>Date</dt> <dd>2014-05-16 11:30:02 -0700 (Fri, 16 May 2014)</dd>
</dl>

<h3>Log Message</h3>
<pre>No longer needed - functionality now included in the dashboard tool.</pre>

<h3>Removed Paths</h3>
<ul>
<li><a href="#CalendarServertrunkcalendarservertoolsschedule_workitemspy">CalendarServer/trunk/calendarserver/tools/schedule_workitems.py</a></li>
<li><a href="#CalendarServertrunkcalendarservertoolsworkitemspy">CalendarServer/trunk/calendarserver/tools/workitems.py</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="CalendarServertrunkcalendarservertoolsschedule_workitemspy"></a>
<div class="delfile"><h4>Deleted: CalendarServer/trunk/calendarserver/tools/schedule_workitems.py (13488 => 13489)</h4>
<pre class="diff"><span>
<span class="info">--- CalendarServer/trunk/calendarserver/tools/schedule_workitems.py        2014-05-16 18:09:01 UTC (rev 13488)
+++ CalendarServer/trunk/calendarserver/tools/schedule_workitems.py        2014-05-16 18:30:02 UTC (rev 13489)
</span><span class="lines">@@ -1,228 +0,0 @@
</span><del>-#!/usr/bin/env python
-
-##
-# Copyright (c) 2006-2014 Apple Inc. All rights reserved.
-#
-# Licensed under the Apache License, Version 2.0 (the &quot;License&quot;);
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an &quot;AS IS&quot; BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-##
-from __future__ import print_function
-
-from getopt import getopt, GetoptError
-import os
-import sys
-import curses
-import datetime
-
-from twisted.internet.defer import inlineCallbacks, succeed
-from calendarserver.tools.cmdline import utilityMain, WorkerService
-from calendarserver.push.notifier import PushNotificationWork
-from txdav.caldav.datastore.scheduling.work import ScheduleOrganizerWork, \
-    ScheduleReplyWork, ScheduleRefreshWork
-
-useCurses = True
-
-def usage(e=None):
-
-    name = os.path.basename(sys.argv[0])
-    print(&quot;usage: %s [options]&quot; % (name,))
-    print(&quot;&quot;)
-    print(&quot;  TODO: describe usage&quot;)
-    print(&quot;&quot;)
-    print(&quot;options:&quot;)
-    print(&quot;  -h --help: print this help and exit&quot;)
-    print(&quot;  -e --error: send stderr to stdout&quot;)
-    print(&quot;  -f --config &lt;path&gt;: Specify caldavd.plist configuration path&quot;)
-    print(&quot;&quot;)
-
-    if e:
-        sys.exit(64)
-    else:
-        sys.exit(0)
-
-
-
-def main():
-
-    try:
-        (optargs, _ignore_args) = getopt(
-            sys.argv[1:], &quot;hef:&quot;, [
-                &quot;help&quot;,
-                &quot;error&quot;,
-                &quot;config=&quot;,
-            ],
-        )
-    except GetoptError, e:
-        usage(e)
-
-    #
-    # Get configuration
-    #
-    configFileName = None
-    debug = False
-
-    for opt, arg in optargs:
-        if opt in (&quot;-h&quot;, &quot;--help&quot;):
-            usage()
-
-        if opt in (&quot;-e&quot;, &quot;--error&quot;):
-            debug = True
-
-        elif opt in (&quot;-f&quot;, &quot;--config&quot;):
-            configFileName = arg
-
-        else:
-            raise NotImplementedError(opt)
-
-    utilityMain(configFileName, WorkItemMonitorService, verbose=debug)
-
-
-
-class WorkItemMonitorService(WorkerService, object):
-
-    def __init__(self, store):
-        super(WorkItemMonitorService, self).__init__(store)
-        from twisted.internet import reactor
-        self.reactor = reactor
-
-
-    def doWork(self):
-        self.screen = curses.initscr() if useCurses else None
-        self.windows = []
-        self.updateScreenGeometry()
-        self.reactor.callLater(0, self.updateDisplay)
-        return succeed(None)
-
-
-    def postStartService(self):
-        &quot;&quot;&quot;
-        Don't quit right away
-        &quot;&quot;&quot;
-        pass
-
-
-    def updateScreenGeometry(self):
-        for win in self.windows:
-            del win
-        winY, winX = self.screen.getmaxyx() if useCurses else (100, 100)
-        seencolumns = [1]
-        seenrows = [1]
-        heightSoFar = 0
-        begin_x = 0
-        begin_y = 0
-        # Specify height and width of each window as one of:
-        #    absolute value (int), e.g.: 42
-        #    percentage of window height / width (string), e.g.: &quot;42%&quot;
-        # Specify row and column for each window as though it is a cell in an invisible html table
-        # Itemize windows in ascending order by row, col
-        for title, height, width, row, col, workItemClass, fmt, attrs in (
-            (&quot;Organizer Requests&quot;, &quot;100%&quot;, &quot;25%&quot;, 1, 1, ScheduleOrganizerWork, &quot;%s: %d&quot;, (&quot;icalendarUid&quot;, &quot;attendeeCount&quot;)),
-            (&quot;Attendee Replies&quot;, &quot;100%&quot;, &quot;25%&quot;, 1, 2, ScheduleReplyWork, &quot;%s&quot;, (&quot;icalendarUid&quot;,)),
-            (&quot;Attendee Refresh&quot;, &quot;100%&quot;, &quot;25%&quot;, 1, 3, ScheduleRefreshWork, &quot;%s: %d&quot;, (&quot;icalendarUid&quot;, &quot;attendeeCount&quot;)),
-#            (&quot;Auto Reply&quot;, &quot;100%&quot;, &quot;25%&quot;, 1, 4, ScheduleAutoReplyWork, &quot;%s&quot;, (&quot;icalendarUid&quot;)),
-            (&quot;Push Notifications&quot;, &quot;100%&quot;, &quot;25%&quot;, 1, 4, PushNotificationWork, &quot;%s: %d&quot;, (&quot;pushID&quot;, &quot;priority&quot;)),
-        ):
-            if (isinstance(height, basestring)):
-                height = max(int(winY * (float(height.strip(&quot;%&quot;)) / 100.0)), 3)
-            if (isinstance(width, basestring)):
-                width = max(int(winX * (float(width.strip(&quot;%&quot;)) / 100.0)), 10)
-            if col not in seencolumns:
-                heightSoFar = max(height, heightSoFar)
-                seencolumns.append(col)
-            if row not in seenrows:
-                begin_y = heightSoFar
-                heightSoFar += height
-                begin_x = 0
-                seenrows.append(row)
-                seencolumns = [col]
-            window = WorkWindow(height, width, begin_y, begin_x,
-                self.store, title, workItemClass, fmt, attrs)
-            self.windows.append(window)
-            begin_x += width
-
-
-    @inlineCallbacks
-    def updateDisplay(self):
-        for window in self.windows:
-            try:
-                yield window.update()
-            except Exception as e:
-                print(str(e))
-        if not useCurses:
-            print(&quot;-------------&quot;)
-
-        self.reactor.callLater(0.1, self.updateDisplay)
-
-
-
-class WorkWindow(object):
-    def __init__(self, nlines, ncols, begin_y, begin_x,
-        store, title, workItemClass, fmt, attrs):
-        self.window = curses.newwin(nlines, ncols, begin_y, begin_x) if useCurses else None
-        self.ncols = ncols
-        self.store = store
-        self.title = title
-        self.workItemClass = workItemClass
-        self.fmt = fmt
-        self.attrs = attrs
-        self.iter = 0
-
-
-    @inlineCallbacks
-    def update(self):
-        txn = self.store.newTransaction()
-        records = (yield self.workItemClass.all(txn))
-        self.iter += 1
-
-        if useCurses:
-            self.window.erase()
-            self.window.border()
-            self.window.addstr(0, 2, self.title + &quot; %d (%d)&quot; % (len(records), self.iter,))
-
-        x = 1
-        y = 1
-        for record in records:
-            txt = &quot;&quot;
-            seconds = record.notBefore - datetime.datetime.utcnow()
-            try:
-                if useCurses:
-                    self.window.addstr(y, x, &quot;%d seconds&quot; % int(seconds.total_seconds()))
-                else:
-                    txt = &quot;%s:&quot; % (self.title,)
-            except curses.error:
-                continue
-            y += 1
-            if self.attrs:
-                try:
-                    s = self.fmt % tuple([getattr(record, str(a)) for a in self.attrs])
-                except Exception, e:
-                    s = &quot;Error: %s&quot; % (str(e),)
-                try:
-                    if useCurses:
-                        self.window.addnstr(y, x, s, self.ncols - 2)
-                    else:
-                        txt += &quot; &quot; + s
-                except curses.error:
-                    pass
-                y += 1
-
-            if not useCurses:
-                print(txt)
-
-        if useCurses:
-            self.window.refresh()
-
-        yield txn.commit()
-
-
-if __name__ == &quot;__main__&quot;:
-    main()
</del></span></pre></div>
<a id="CalendarServertrunkcalendarservertoolsworkitemspy"></a>
<div class="delfile"><h4>Deleted: CalendarServer/trunk/calendarserver/tools/workitems.py (13488 => 13489)</h4>
<pre class="diff"><span>
<span class="info">--- CalendarServer/trunk/calendarserver/tools/workitems.py        2014-05-16 18:09:01 UTC (rev 13488)
+++ CalendarServer/trunk/calendarserver/tools/workitems.py        2014-05-16 18:30:02 UTC (rev 13489)
</span><span class="lines">@@ -1,231 +0,0 @@
</span><del>-#!/usr/bin/env python
-
-##
-# Copyright (c) 2006-2014 Apple Inc. All rights reserved.
-#
-# Licensed under the Apache License, Version 2.0 (the &quot;License&quot;);
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an &quot;AS IS&quot; BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-##
-from __future__ import print_function
-
-from getopt import getopt, GetoptError
-import os
-import sys
-import curses
-import datetime
-
-from twisted.internet.defer import inlineCallbacks, succeed
-from calendarserver.tools.cmdline import utilityMain, WorkerService
-from calendarserver.push.notifier import PushNotificationWork
-from txdav.who.groups import GroupCacherPollingWork
-from txdav.caldav.datastore.scheduling.imip.inbound import (
-    IMIPPollingWork, IMIPReplyWork
-)
-
-
-
-def usage(e=None):
-
-    name = os.path.basename(sys.argv[0])
-    print(&quot;usage: %s [options]&quot; % (name,))
-    print(&quot;&quot;)
-    print(&quot;  TODO: describe usage&quot;)
-    print(&quot;&quot;)
-    print(&quot;options:&quot;)
-    print(&quot;  -h --help: print this help and exit&quot;)
-    print(&quot;  -e --error: send stderr to stdout&quot;)
-    print(&quot;  -f --config &lt;path&gt;: Specify caldavd.plist configuration path&quot;)
-    print(&quot;&quot;)
-
-    if e:
-        sys.exit(64)
-    else:
-        sys.exit(0)
-
-
-
-def main():
-
-    try:
-        (optargs, _ignore_args) = getopt(
-            sys.argv[1:], &quot;hef:&quot;, [
-                &quot;help&quot;,
-                &quot;error&quot;,
-                &quot;config=&quot;,
-            ],
-        )
-    except GetoptError, e:
-        usage(e)
-
-    #
-    # Get configuration
-    #
-    configFileName = None
-    debug = False
-
-    for opt, arg in optargs:
-        if opt in (&quot;-h&quot;, &quot;--help&quot;):
-            usage()
-
-        if opt in (&quot;-e&quot;, &quot;--error&quot;):
-            debug = True
-
-        elif opt in (&quot;-f&quot;, &quot;--config&quot;):
-            configFileName = arg
-
-        else:
-            raise NotImplementedError(opt)
-
-    utilityMain(configFileName, WorkItemMonitorService, verbose=debug)
-
-
-
-class WorkItemMonitorService(WorkerService, object):
-
-    def __init__(self, store):
-        super(WorkItemMonitorService, self).__init__(store)
-        from twisted.internet import reactor
-        self.reactor = reactor
-
-
-    def doWork(self):
-        self.screen = curses.initscr()
-        self.windows = []
-        self.updateScreenGeometry()
-        self.reactor.callLater(0, self.updateDisplay)
-        return succeed(None)
-
-
-    def postStartService(self):
-        &quot;&quot;&quot;
-        Don't quit right away
-        &quot;&quot;&quot;
-        pass
-
-
-    def updateScreenGeometry(self):
-        for win in self.windows:
-            del win
-        winY, winX = self.screen.getmaxyx()
-        seencolumns = [1]
-        seenrows = [1]
-        heightSoFar = 0
-        begin_x = 0
-        begin_y = 0
-        # Specify height and width of each window as one of:
-        #    absolute value (int), e.g.: 42
-        #    percentage of window height / width (string), e.g.: &quot;42%&quot;
-        # Specify row and column for each window as though it is a cell in an
-        # invisible html table
-        # Itemize windows in ascending order by row, col
-        for title, height, width, row, col, workItemClass, fmt, attrs in (
-            (
-                &quot;Group Membership Indexing&quot;,
-                &quot;10%&quot;, &quot;50%&quot;, 1, 1,
-                GroupCacherPollingWork, &quot;&quot;, ()
-            ),
-            (
-                &quot;IMIP Reply Polling&quot;,
-                &quot;10%&quot;, &quot;50%&quot;, 1, 2,
-                IMIPPollingWork, &quot;&quot;, ()
-            ),
-            (
-                &quot;IMIP Reply Processing&quot;,
-                &quot;20%&quot;, &quot;100%&quot;, 2, 1,
-                IMIPReplyWork, &quot;%s %s&quot;, (&quot;organizer&quot;, &quot;attendee&quot;)
-            ),
-            (
-                &quot;Push Notifications&quot;,
-                &quot;69%&quot;, &quot;100%&quot;, 3, 1,
-                PushNotificationWork, &quot;%s&quot;, (&quot;pushID&quot;,)
-            ),
-        ):
-            if (isinstance(height, basestring)):
-                height = max(int(winY * (float(height.strip(&quot;%&quot;)) / 100.0)), 3)
-            if (isinstance(width, basestring)):
-                width = max(int(winX * (float(width.strip(&quot;%&quot;)) / 100.0)), 10)
-            if col not in seencolumns:
-                heightSoFar = max(height, heightSoFar)
-                seencolumns.append(col)
-            if row not in seenrows:
-                begin_y = heightSoFar
-                heightSoFar += height
-                begin_x = 0
-                seenrows.append(row)
-                seencolumns = [col]
-            window = WorkWindow(
-                height, width, begin_y, begin_x,
-                self.store, title, workItemClass, fmt, attrs
-            )
-            self.windows.append(window)
-            begin_x += width
-
-
-    @inlineCallbacks
-    def updateDisplay(self):
-        for window in self.windows:
-            yield window.update()
-
-        self.reactor.callLater(1, self.updateDisplay)
-
-
-
-class WorkWindow(object):
-    def __init__(
-        self, nlines, ncols, begin_y, begin_x,
-        store, title, workItemClass, fmt, attrs
-    ):
-        self.window = curses.newwin(nlines, ncols, begin_y, begin_x)
-        self.ncols = ncols
-        self.store = store
-        self.title = title
-        self.workItemClass = workItemClass
-        self.fmt = fmt
-        self.attrs = attrs
-
-
-    @inlineCallbacks
-    def update(self):
-        self.window.erase()
-        self.window.border()
-        self.window.addstr(0, 2, self.title)
-        txn = self.store.newTransaction()
-        records = (yield self.workItemClass.all(txn))
-
-        x = 1
-        y = 1
-        for record in records:
-            seconds = record.notBefore - datetime.datetime.utcnow()
-            try:
-                self.window.addstr(
-                    y, x,
-                    &quot;%d seconds&quot; % int(seconds.total_seconds())
-                )
-            except curses.error:
-                continue
-            y += 1
-            if self.attrs:
-                try:
-                    s = self.fmt % tuple(
-                        [getattr(record, str(a)) for a in self.attrs]
-                    )
-                except Exception, e:
-                    s = &quot;Error: %s&quot; % (str(e),)
-                try:
-                    self.window.addnstr(y, x, s, self.ncols - 2)
-                except curses.error:
-                    pass
-                y += 1
-        self.window.refresh()
-
-if __name__ == &quot;__main__&quot;:
-    main()
</del></span></pre>
</div>
</div>

</body>
</html>