~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to www/media/common/util.js

  • Committer: mattgiuca
  • Date: 2008-05-11 05:11:09 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:754
listusers.py: Added options processing (now accepts -h and -n).
    If -n is given, just prints out a list of usernames, rather than
    all the user details.

Show diffs side-by-side

added added

removed removed

Lines of Context:
311
311
    if (("path" in obj) && obj.path != null)
312
312
    {
313
313
        var path = urlencode_path(obj.path.toString());
314
 
        if (url.length > 0 && path.length > 0 && path.charAt(0) != "/")
 
314
        if (url.length > 0 && path.length > 0 && path[0] != "/")
315
315
            path = "/" + path;
316
316
        url += path;
317
317
    }
426
426
    {
427
427
        arg = arguments[i];
428
428
        if (arg.length == 0) continue;
429
 
        if (arg.charAt(0) == '/')
 
429
        if (arg[0] == '/')
430
430
            path = arg;
431
431
        else
432
432
        {
433
 
            if (path.length > 0 && path.charAt(path.length-1) != '/')
 
433
            if (path.length > 0 && path[path.length-1] != '/')
434
434
                path += '/';
435
435
            path += arg;
436
436
        }
491
491
function pathlist_to_path(pathlist)
492
492
{
493
493
    ret = path_join.apply(null, pathlist);
494
 
    if (ret.charAt(ret.length-1) != '/')
 
494
    if (ret[ret.length-1] != '/')
495
495
        ret += '/';
496
496
    return ret;
497
497
}
538
538
    return str.substr(str.length - substring.length) == substring;
539
539
}
540
540
 
 
541
/** Equivalent to Python's repr.
 
542
 * Gets the JavaScript string representation.
 
543
 * Actually just calls JSON.stringify.
 
544
 */
 
545
function repr(str)
 
546
{
 
547
    return JSON.stringify(str);
 
548
}
 
549
 
541
550
/** Removes all occurences of a value from an array.
542
551
 */
543
552
Array.prototype.removeall = function(val)
594
603
    }
595
604
}
596
605
 
597
 
/** Creates a random string of length length,
598
 
 * consisting of alphanumeric characters.
599
 
 */
600
 
var rand_chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZ"
601
 
               + "abcdefghiklmnopqrstuvwxyz";
602
 
function random_string(length)
603
 
{
604
 
    var str = Array(length);
605
 
    var v;
606
 
    for (var i=0; i<length; i++)
607
 
    {
608
 
        v = Math.floor(Math.random() * rand_chars.length);
609
 
        str[i] = rand_chars.charAt(v);
610
 
    }
611
 
    return str.join('');
612
 
}
613
 
 
614
 
/** Makes an XMLHttpRequest call to the server.
 
606
/** Makes an asynchronous XMLHttpRequest call to the server.
615
607
 * Sends the XMLHttpRequest object containing the completed response to a
616
608
 * specified callback function.
617
609
 *
618
610
 * \param callback A callback function. Will be called when the response is
619
611
 *      complete. Passed 1 parameter, an XMLHttpRequest object containing the
620
 
 *      completed response. If callback is null this is a syncronous request 
621
 
 *      otherwise this is an asynchronous request.
 
612
 *      completed response.
622
613
 * \param app IVLE app to call (such as "fileservice").
623
614
 * \param path URL path to make the request to, within the application.
624
615
 * \param args Argument object, as described in parse_url and friends.
636
627
    /* A random string, for multipart/form-data
637
628
     * (This is not checked against anywhere else, it is solely defined and
638
629
     * used within this function) */
639
 
    var boundary = random_string(20);
 
630
    var boundary = "48234n334nu7n4n2ynonjn234t683jyh80j";
640
631
    var xhr = new_xmlhttprequest();
641
 
    var asyncronous = callback != null;
642
 
    if (asyncronous)
643
 
    {
644
 
        xhr.onreadystatechange = function()
 
632
    xhr.onreadystatechange = function()
 
633
        {
 
634
            if (xhr.readyState == 4)
645
635
            {
646
 
                if (xhr.readyState == 4)
647
 
                {
648
 
                    callback(xhr);
649
 
                }
 
636
                callback(xhr);
650
637
            }
651
 
    }
 
638
        }
652
639
    if (method == "GET")
653
640
    {
654
641
        /* GET sends the args in the URL */
655
642
        url = build_url({"path": path, "args": args});
656
643
        /* open's 3rd argument = true -> asynchronous */
657
 
        xhr.open(method, url, asyncronous);
 
644
        xhr.open(method, url, true);
658
645
        xhr.send(null);
659
646
    }
660
647
    else
661
648
    {
662
649
        /* POST sends the args in application/x-www-form-urlencoded */
663
650
        url = encodeURI(path);
664
 
        xhr.open(method, url, asyncronous);
 
651
        xhr.open(method, url, true);
665
652
        var message;
666
653
        if (content_type == "multipart/form-data")
667
654
        {
668
655
            xhr.setRequestHeader("Content-Type",
669
 
                "multipart/form-data; boundary=" + boundary);
 
656
                "multipart/form-data, boundary=" + boundary);
670
657
            message = make_multipart_formdata(args, boundary);
671
658
        }
672
659
        else
674
661
            xhr.setRequestHeader("Content-Type", content_type);
675
662
            message = make_query_string(args);
676
663
        }
 
664
        xhr.setRequestHeader("Content-Length", message.length);
677
665
        xhr.send(message);
678
666
    }
679
 
    /* Only return the XHR for syncronous requests */
680
 
    if (!asyncronous)
681
 
    { 
682
 
        return xhr;
683
 
    }
684
667
}
685
668
 
686
 
/** Attempts to JSON decodes a response object
687
 
 * If a non-200 response or the JSON decode fails then returns null
688
 
 */
689
 
function decode_response(response)
690
 
{
691
 
    if (response.status == 200)
692
 
    {
693
 
        try
694
 
        {
695
 
            var responseText = response.responseText;
696
 
            return JSON.parse(responseText);
697
 
        }
698
 
        catch (e)
699
 
        {
700
 
            // Pass
701
 
        }
702
 
     }
703
 
    
704
 
     return null;
705
 
}