Files @ 7e3d89d9d3a2
Branch filter:

Location: kallithea/rhodecode/config/routing.py - annotation

Marcin Kuzminski
- Manage User’s Groups: create, delete, rename, add/remove users inside.
by user group admin.
In this case, a user's group can be owned by several people thru an owner user's group.

Some refactoring of naming, permission handling logic.
- remove some code duplicity as well as inconsistent naming
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
5cc96df705b9
5cc96df705b9
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
bb6ba7442293
74aae890d33e
74aae890d33e
74aae890d33e
f4807acf643d
1e757ac98988
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
a7e7c0fab9db
27be8f94c207
7d687ed11929
7d687ed11929
27be8f94c207
5cc96df705b9
5cc96df705b9
5cc96df705b9
2aee0dc1784e
5cc96df705b9
5cc96df705b9
5cc96df705b9
a8c66e870bd0
a8c66e870bd0
27be8f94c207
ec483ce69ad9
ec483ce69ad9
ec483ce69ad9
ec483ce69ad9
a8c66e870bd0
a8c66e870bd0
1670ee0aded7
a8c66e870bd0
a8c66e870bd0
10b4e34841a4
a8c66e870bd0
a8c66e870bd0
7d687ed11929
bb6ba7442293
bb6ba7442293
bb6ba7442293
5706f6ab60cf
2aee0dc1784e
bb6ba7442293
bb6ba7442293
bb6ba7442293
bb6ba7442293
7d687ed11929
5cc96df705b9
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
0ad025ee005e
dccba44ee176
dccba44ee176
dccba44ee176
1e757ac98988
1e757ac98988
a7e7c0fab9db
a7e7c0fab9db
1e757ac98988
5cc96df705b9
1e757ac98988
5cc96df705b9
5cc96df705b9
5cc96df705b9
a7e7c0fab9db
a2dba9356c64
a2dba9356c64
1f75b23c3e26
cac5109ac3b6
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
cf370b6d3977
cf370b6d3977
cf370b6d3977
a7e7c0fab9db
0e6035a85980
5cc96df705b9
74aae890d33e
74aae890d33e
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
1e757ac98988
77e6e941001f
802c94bdfc85
1f75b23c3e26
1e757ac98988
1e757ac98988
1f75b23c3e26
1e757ac98988
1e757ac98988
1f75b23c3e26
1e757ac98988
1e757ac98988
1f75b23c3e26
1e757ac98988
1e757ac98988
1f75b23c3e26
1e757ac98988
1e757ac98988
c734686b3cf2
c734686b3cf2
c734686b3cf2
c734686b3cf2
c734686b3cf2
1e757ac98988
1f75b23c3e26
87f0800abc7b
87f0800abc7b
87f0800abc7b
65129c332d37
a7e7c0fab9db
1f75b23c3e26
a7e7c0fab9db
a7e7c0fab9db
65129c332d37
b9bbc0d6e9f3
1f75b23c3e26
1088ded6e602
1088ded6e602
1f75b23c3e26
1088ded6e602
1088ded6e602
1f75b23c3e26
1088ded6e602
b9bbc0d6e9f3
1f75b23c3e26
1088ded6e602
1088ded6e602
1f75b23c3e26
1088ded6e602
1088ded6e602
aa17c7a1b8a5
aa17c7a1b8a5
aa17c7a1b8a5
802c94bdfc85
802c94bdfc85
802c94bdfc85
802c94bdfc85
72a91632b731
72a91632b731
72a91632b731
72a91632b731
72a91632b731
72a91632b731
72a91632b731
72a91632b731
2f3cba7b6d16
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
dccba44ee176
b4daef4cc26d
dccba44ee176
b4daef4cc26d
b4daef4cc26d
dccba44ee176
0ad025ee005e
b4daef4cc26d
0ad025ee005e
0ad025ee005e
dccba44ee176
b4daef4cc26d
dccba44ee176
b4daef4cc26d
b4daef4cc26d
dccba44ee176
b4daef4cc26d
b4daef4cc26d
dccba44ee176
b4daef4cc26d
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
4c78a0855a17
87f0800abc7b
b4daef4cc26d
87f0800abc7b
87f0800abc7b
87f0800abc7b
4c78a0855a17
87f0800abc7b
b4daef4cc26d
87f0800abc7b
87f0800abc7b
fff21c9b075c
fff21c9b075c
74aae890d33e
74aae890d33e
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
a1bcfe58a1ab
b0fef8a77568
b0fef8a77568
b0fef8a77568
b0fef8a77568
9b92cf5a0cca
9b92cf5a0cca
9b92cf5a0cca
9b92cf5a0cca
fff21c9b075c
5f1850e4712a
74aae890d33e
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
aa7e45ad0cea
7e3d89d9d3a2
7e3d89d9d3a2
aa7e45ad0cea
83d35d716a02
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
7e3d89d9d3a2
83d35d716a02
a1bcfe58a1ab
74aae890d33e
5cc96df705b9
5cc96df705b9
a7e7c0fab9db
74aae890d33e
4bdcc08b04c4
6104dfd35b16
6104dfd35b16
6104dfd35b16
6104dfd35b16
4bdcc08b04c4
74aae890d33e
a7e7c0fab9db
a7e7c0fab9db
a1bcfe58a1ab
74aae890d33e
a7e7c0fab9db
9e9f1b919c0c
5cc96df705b9
74aae890d33e
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
1e757ac98988
a7e7c0fab9db
19daa8d761dc
19daa8d761dc
19daa8d761dc
19daa8d761dc
19daa8d761dc
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
2aee0dc1784e
2aee0dc1784e
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
cac5109ac3b6
5cc96df705b9
74aae890d33e
74aae890d33e
a7e7c0fab9db
1e757ac98988
1e757ac98988
49eb69d78988
c78f6bf52e9c
87f0800abc7b
c78f6bf52e9c
c78f6bf52e9c
c78f6bf52e9c
c78f6bf52e9c
c78f6bf52e9c
a7e7c0fab9db
d815d617eb5e
d815d617eb5e
d815d617eb5e
d815d617eb5e
d815d617eb5e
d815d617eb5e
49eb69d78988
74aae890d33e
a7e7c0fab9db
a7e7c0fab9db
b0d09c20f608
b0d09c20f608
b0d09c20f608
b0d09c20f608
a7e7c0fab9db
fee472613dfa
74aae890d33e
b0d09c20f608
b0d09c20f608
b0d09c20f608
b0d09c20f608
74aae890d33e
74aae890d33e
49eb69d78988
74aae890d33e
a7e7c0fab9db
a7e7c0fab9db
49eb69d78988
1e757ac98988
74aae890d33e
666fc6ac9ce5
b38230cf8710
b38230cf8710
666fc6ac9ce5
666fc6ac9ce5
666fc6ac9ce5
666fc6ac9ce5
5cc96df705b9
1e757ac98988
74aae890d33e
74aae890d33e
a7e7c0fab9db
a7e7c0fab9db
74aae890d33e
a7e7c0fab9db
a7e7c0fab9db
74aae890d33e
a7e7c0fab9db
5cc96df705b9
5875955def39
5875955def39
5875955def39
5875955def39
1e757ac98988
1f75b23c3e26
1e757ac98988
1e757ac98988
a7e7c0fab9db
1f75b23c3e26
1e757ac98988
1e757ac98988
5cc96df705b9
cb216757a62d
cb216757a62d
cb216757a62d
1f75b23c3e26
27be8f94c207
bb6ba7442293
27be8f94c207
b9ba0d4d3abf
b9ba0d4d3abf
b9ba0d4d3abf
b9ba0d4d3abf
27be8f94c207
27be8f94c207
27be8f94c207
27be8f94c207
1f75b23c3e26
1e757ac98988
1e757ac98988
a7e7c0fab9db
802c94bdfc85
802c94bdfc85
802c94bdfc85
802c94bdfc85
802c94bdfc85
802c94bdfc85
802c94bdfc85
6cdf2cd9d9d8
6cdf2cd9d9d8
6cdf2cd9d9d8
6cdf2cd9d9d8
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
ebe3e388bbb3
87f0800abc7b
1f75b23c3e26
d2de0c2f02cd
d2de0c2f02cd
d2de0c2f02cd
45df84d36b44
45df84d36b44
45df84d36b44
45df84d36b44
45df84d36b44
87f0800abc7b
1f75b23c3e26
d2de0c2f02cd
cac5109ac3b6
d2de0c2f02cd
2bfcec6a3985
2bfcec6a3985
2bfcec6a3985
745dda7817ed
0ebdd15de1d8
b2a2868d7bec
745dda7817ed
f4ff3b5bfc42
c9b0f1d363c7
c9b0f1d363c7
f4ff3b5bfc42
b2a2868d7bec
77e376fdc4c6
1f75b23c3e26
f29469677319
f29469677319
f29469677319
f29469677319
1f75b23c3e26
f29469677319
f29469677319
f29469677319
f29469677319
1f75b23c3e26
f29469677319
f29469677319
f29469677319
3f50a5e8fc4d
1f75b23c3e26
3f50a5e8fc4d
3f50a5e8fc4d
3f50a5e8fc4d
49a4864b11c1
49a4864b11c1
49a4864b11c1
49a4864b11c1
49a4864b11c1
77e376fdc4c6
1bc579bcd67a
1f75b23c3e26
1bc579bcd67a
1bc579bcd67a
1bc579bcd67a
1bc579bcd67a
fd0a822481ec
1f75b23c3e26
fd0a822481ec
fd0a822481ec
fd0a822481ec
fd0a822481ec
a0adf8db1416
1f75b23c3e26
a0adf8db1416
a0adf8db1416
a0adf8db1416
a34b98423de7
1e757ac98988
a7e7c0fab9db
1f75b23c3e26
1e757ac98988
a7e7c0fab9db
a520d542697e
a520d542697e
a520d542697e
a520d542697e
1f75b23c3e26
1e757ac98988
a7e7c0fab9db
1f75b23c3e26
1e757ac98988
a7e7c0fab9db
1f75b23c3e26
a3ee2611e6e8
a3ee2611e6e8
1f75b23c3e26
5cc96df705b9
a7e7c0fab9db
1f75b23c3e26
d5d7c40e8591
d5d7c40e8591
d5d7c40e8591
1f75b23c3e26
1e757ac98988
1e757ac98988
a7e7c0fab9db
c177f304eb40
c177f304eb40
c177f304eb40
c177f304eb40
37c7abd34d44
37c7abd34d44
37c7abd34d44
37c7abd34d44
37c7abd34d44
1f75b23c3e26
1e757ac98988
1e757ac98988
a7e7c0fab9db
a7e7c0fab9db
1f75b23c3e26
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
1f75b23c3e26
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
a7e7c0fab9db
1f75b23c3e26
ee07357d9265
ee07357d9265
a7e7c0fab9db
166317d464f3
1f75b23c3e26
166317d464f3
166317d464f3
166317d464f3
7b67b0dcad6d
1f75b23c3e26
7b67b0dcad6d
7b67b0dcad6d
7b67b0dcad6d
1f75b23c3e26
b956e6f415a2
5cc96df705b9
a7e7c0fab9db
8585fbf3ed06
1f75b23c3e26
8585fbf3ed06
8585fbf3ed06
8585fbf3ed06
1f75b23c3e26
e7eef7a1db6a
1e757ac98988
a7e7c0fab9db
1f75b23c3e26
e7eef7a1db6a
1e757ac98988
5cc96df705b9
1f75b23c3e26
e7eef7a1db6a
e7eef7a1db6a
e7eef7a1db6a
1f75b23c3e26
cb216757a62d
cb216757a62d
7e75af301842
a7e7c0fab9db
"""
Routes configuration

The more specific and detailed routes should be defined first so they
may take precedent over the more generic routes. For more information
refer to the routes manual at http://routes.groovie.org/docs/
"""
from __future__ import with_statement
from routes import Mapper

# prefix for non repository related links needs to be prefixed with `/`
ADMIN_PREFIX = '/_admin'


def make_map(config):
    """Create, configure and return the routes Mapper"""
    rmap = Mapper(directory=config['pylons.paths']['controllers'],
                 always_scan=config['debug'])
    rmap.minimization = False
    rmap.explicit = False

    from rhodecode.lib.utils import is_valid_repo
    from rhodecode.lib.utils import is_valid_repos_group

    def check_repo(environ, match_dict):
        """
        check for valid repository for proper 404 handling

        :param environ:
        :param match_dict:
        """
        from rhodecode.model.db import Repository
        repo_name = match_dict.get('repo_name')

        if match_dict.get('f_path'):
            #fix for multiple initial slashes that causes errors
            match_dict['f_path'] = match_dict['f_path'].lstrip('/')

        try:
            by_id = repo_name.split('_')
            if len(by_id) == 2 and by_id[1].isdigit() and by_id[0] == '':
                repo_name = Repository.get(by_id[1]).repo_name
                match_dict['repo_name'] = repo_name
        except Exception:
            pass

        return is_valid_repo(repo_name, config['base_path'])

    def check_group(environ, match_dict):
        """
        check for valid repository group for proper 404 handling

        :param environ:
        :param match_dict:
        """
        repos_group_name = match_dict.get('group_name')
        return is_valid_repos_group(repos_group_name, config['base_path'])

    def check_group_skip_path(environ, match_dict):
        """
        check for valid repository group for proper 404 handling, but skips
        verification of existing path

        :param environ:
        :param match_dict:
        """
        repos_group_name = match_dict.get('group_name')
        return is_valid_repos_group(repos_group_name, config['base_path'],
                                    skip_path_check=True)

    def check_int(environ, match_dict):
        return match_dict.get('id').isdigit()

    # The ErrorController route (handles 404/500 error pages); it should
    # likely stay at the top, ensuring it can always be resolved
    rmap.connect('/error/{action}', controller='error')
    rmap.connect('/error/{action}/{id}', controller='error')

    #==========================================================================
    # CUSTOM ROUTES HERE
    #==========================================================================

    #MAIN PAGE
    rmap.connect('home', '/', controller='home', action='index')
    rmap.connect('repo_switcher', '/repos', controller='home',
                 action='repo_switcher')
    rmap.connect('branch_tag_switcher', '/branches-tags/{repo_name:.*?}',
                 controller='home', action='branch_tag_switcher')
    rmap.connect('bugtracker',
                 "http://bitbucket.org/marcinkuzminski/rhodecode/issues",
                 _static=True)
    rmap.connect('rst_help',
                 "http://docutils.sourceforge.net/docs/user/rst/quickref.html",
                 _static=True)
    rmap.connect('rhodecode_official', "http://rhodecode.org", _static=True)

    #ADMIN REPOSITORY REST ROUTES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/repos') as m:
        m.connect("repos", "/repos",
             action="create", conditions=dict(method=["POST"]))
        m.connect("repos", "/repos",
             action="index", conditions=dict(method=["GET"]))
        m.connect("formatted_repos", "/repos.{format}",
             action="index",
            conditions=dict(method=["GET"]))
        m.connect("new_repo", "/create_repository",
                  action="create_repository", conditions=dict(method=["GET"]))
        m.connect("/repos/{repo_name:.*?}",
             action="update", conditions=dict(method=["PUT"],
                                              function=check_repo))
        m.connect("/repos/{repo_name:.*?}",
             action="delete", conditions=dict(method=["DELETE"],
                                              function=check_repo))
        m.connect("formatted_edit_repo", "/repos/{repo_name:.*?}.{format}/edit",
             action="edit", conditions=dict(method=["GET"],
                                            function=check_repo))
        m.connect("repo", "/repos/{repo_name:.*?}",
             action="show", conditions=dict(method=["GET"],
                                            function=check_repo))
        m.connect("formatted_repo", "/repos/{repo_name:.*?}.{format}",
             action="show", conditions=dict(method=["GET"],
                                            function=check_repo))
        #add repo perm member
        m.connect('set_repo_perm_member', "/set_repo_perm_member/{repo_name:.*?}",
             action="set_repo_perm_member",
             conditions=dict(method=["POST"], function=check_repo))

        #ajax delete repo perm user
        m.connect('delete_repo_user', "/repos_delete_user/{repo_name:.*?}",
             action="delete_perm_user",
             conditions=dict(method=["DELETE"], function=check_repo))

        #ajax delete repo perm users_group
        m.connect('delete_repo_users_group',
                  "/repos_delete_users_group/{repo_name:.*?}",
                  action="delete_perm_users_group",
                  conditions=dict(method=["DELETE"], function=check_repo))

        #settings actions
        m.connect('repo_stats', "/repos_stats/{repo_name:.*?}",
                  action="repo_stats", conditions=dict(method=["DELETE"],
                                                       function=check_repo))
        m.connect('repo_cache', "/repos_cache/{repo_name:.*?}",
                  action="repo_cache", conditions=dict(method=["DELETE"],
                                                       function=check_repo))
        m.connect('repo_public_journal', "/repos_public_journal/{repo_name:.*?}",
                  action="repo_public_journal", conditions=dict(method=["PUT"],
                                                        function=check_repo))
        m.connect('repo_pull', "/repo_pull/{repo_name:.*?}",
                  action="repo_pull", conditions=dict(method=["PUT"],
                                                      function=check_repo))
        m.connect('repo_as_fork', "/repo_as_fork/{repo_name:.*?}",
                  action="repo_as_fork", conditions=dict(method=["PUT"],
                                                      function=check_repo))
        m.connect('repo_locking', "/repo_locking/{repo_name:.*?}",
                  action="repo_locking", conditions=dict(method=["PUT"],
                                                      function=check_repo))
        m.connect('toggle_locking', "/locking_toggle/{repo_name:.*?}",
                  action="toggle_locking", conditions=dict(method=["GET"],
                                                      function=check_repo))

        #repo fields
        m.connect('create_repo_fields', "/repo_fields/{repo_name:.*?}/new",
                  action="create_repo_field", conditions=dict(method=["PUT"],
                                                      function=check_repo))

        m.connect('delete_repo_fields', "/repo_fields/{repo_name:.*?}/{field_id}",
                  action="delete_repo_field", conditions=dict(method=["DELETE"],
                                                      function=check_repo))

    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/repos_groups') as m:
        m.connect("repos_groups", "/repos_groups",
                  action="create", conditions=dict(method=["POST"]))
        m.connect("repos_groups", "/repos_groups",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("formatted_repos_groups", "/repos_groups.{format}",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("new_repos_group", "/repos_groups/new",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("formatted_new_repos_group", "/repos_groups/new.{format}",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("update_repos_group", "/repos_groups/{group_name:.*?}",
                  action="update", conditions=dict(method=["PUT"],
                                                   function=check_group))
        m.connect("delete_repos_group", "/repos_groups/{group_name:.*?}",
                  action="delete", conditions=dict(method=["DELETE"],
                                                   function=check_group_skip_path))
        m.connect("edit_repos_group", "/repos_groups/{group_name:.*?}/edit",
                  action="edit", conditions=dict(method=["GET"],
                                                 function=check_group))
        m.connect("formatted_edit_repos_group",
                  "/repos_groups/{group_name:.*?}.{format}/edit",
                  action="edit", conditions=dict(method=["GET"],
                                                 function=check_group))
        m.connect("repos_group", "/repos_groups/{group_name:.*?}",
                  action="show", conditions=dict(method=["GET"],
                                                 function=check_group))
        m.connect("formatted_repos_group", "/repos_groups/{group_name:.*?}.{format}",
                  action="show", conditions=dict(method=["GET"],
                                                 function=check_group))

        #add repo perm member
        m.connect('set_repo_group_perm_member',
                  "/set_repo_group_perm_member/{group_name:.*?}",
             action="set_repo_group_perm_member",
             conditions=dict(method=["POST"], function=check_group))

        # ajax delete repository group perm user
        m.connect('delete_repos_group_user_perm',
                  "/delete_repos_group_user_perm/{group_name:.*?}",
             action="delete_repos_group_user_perm",
             conditions=dict(method=["DELETE"], function=check_group))

        # ajax delete repository group perm users_group
        m.connect('delete_repos_group_users_group_perm',
                  "/delete_repos_group_users_group_perm/{group_name:.*?}",
                  action="delete_repos_group_users_group_perm",
                  conditions=dict(method=["DELETE"], function=check_group))

    #ADMIN USER REST ROUTES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/users') as m:
        m.connect("users", "/users",
                  action="create", conditions=dict(method=["POST"]))
        m.connect("users", "/users",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("formatted_users", "/users.{format}",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("new_user", "/users/new",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("formatted_new_user", "/users/new.{format}",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("update_user", "/users/{id}",
                  action="update", conditions=dict(method=["PUT"]))
        m.connect("delete_user", "/users/{id}",
                  action="delete", conditions=dict(method=["DELETE"]))
        m.connect("edit_user", "/users/{id}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("formatted_edit_user",
                  "/users/{id}.{format}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("user", "/users/{id}",
                  action="show", conditions=dict(method=["GET"]))
        m.connect("formatted_user", "/users/{id}.{format}",
                  action="show", conditions=dict(method=["GET"]))

        #EXTRAS USER ROUTES
        m.connect("user_perm", "/users_perm/{id}",
                  action="update_perm", conditions=dict(method=["PUT"]))
        m.connect("user_emails", "/users_emails/{id}",
                  action="add_email", conditions=dict(method=["PUT"]))
        m.connect("user_emails_delete", "/users_emails/{id}",
                  action="delete_email", conditions=dict(method=["DELETE"]))
        m.connect("user_ips", "/users_ips/{id}",
                  action="add_ip", conditions=dict(method=["PUT"]))
        m.connect("user_ips_delete", "/users_ips/{id}",
                  action="delete_ip", conditions=dict(method=["DELETE"]))

    #ADMIN USER GROUPS REST ROUTES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/users_groups') as m:
        m.connect("users_groups", "/users_groups",
                  action="create", conditions=dict(method=["POST"]))
        m.connect("users_groups", "/users_groups",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("formatted_users_groups", "/users_groups.{format}",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("new_users_group", "/users_groups/new",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("formatted_new_users_group", "/users_groups/new.{format}",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("update_users_group", "/users_groups/{id}",
                  action="update", conditions=dict(method=["PUT"]))
        m.connect("delete_users_group", "/users_groups/{id}",
                  action="delete", conditions=dict(method=["DELETE"]))
        m.connect("edit_users_group", "/users_groups/{id}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("formatted_edit_users_group",
                  "/users_groups/{id}.{format}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("users_group", "/users_groups/{id}",
                  action="show", conditions=dict(method=["GET"]))
        m.connect("formatted_users_group", "/users_groups/{id}.{format}",
                  action="show", conditions=dict(method=["GET"]))

        #EXTRAS USER ROUTES
        # update
        m.connect("users_group_perm", "/users_groups/{id}/update_global_perm",
                  action="update_perm", conditions=dict(method=["PUT"]))

        #add user group perm member
        m.connect('set_user_group_perm_member', "/users_groups/{id}/grant_perm",
             action="set_user_group_perm_member",
             conditions=dict(method=["POST"]))

        #ajax delete user group perm
        m.connect('delete_user_group_perm_member', "/users_groups/{id}/revoke_perm",
             action="delete_user_group_perm_member",
             conditions=dict(method=["DELETE"]))

    #ADMIN GROUP REST ROUTES
    rmap.resource('group', 'groups',
                  controller='admin/groups', path_prefix=ADMIN_PREFIX)

    #ADMIN PERMISSIONS REST ROUTES
    rmap.resource('permission', 'permissions',
                  controller='admin/permissions', path_prefix=ADMIN_PREFIX)

    #ADMIN DEFAULTS REST ROUTES
    rmap.resource('default', 'defaults',
                  controller='admin/defaults', path_prefix=ADMIN_PREFIX)

    ##ADMIN LDAP SETTINGS
    rmap.connect('ldap_settings', '%s/ldap' % ADMIN_PREFIX,
                 controller='admin/ldap_settings', action='ldap_settings',
                 conditions=dict(method=["POST"]))

    rmap.connect('ldap_home', '%s/ldap' % ADMIN_PREFIX,
                 controller='admin/ldap_settings')

    #ADMIN SETTINGS REST ROUTES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/settings') as m:
        m.connect("admin_settings", "/settings",
                  action="create", conditions=dict(method=["POST"]))
        m.connect("admin_settings", "/settings",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("formatted_admin_settings", "/settings.{format}",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("admin_new_setting", "/settings/new",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("formatted_admin_new_setting", "/settings/new.{format}",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("/settings/{setting_id}",
                  action="update", conditions=dict(method=["PUT"]))
        m.connect("/settings/{setting_id}",
                  action="delete", conditions=dict(method=["DELETE"]))
        m.connect("admin_edit_setting", "/settings/{setting_id}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("formatted_admin_edit_setting",
                  "/settings/{setting_id}.{format}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("admin_setting", "/settings/{setting_id}",
                  action="show", conditions=dict(method=["GET"]))
        m.connect("formatted_admin_setting", "/settings/{setting_id}.{format}",
                  action="show", conditions=dict(method=["GET"]))
        m.connect("admin_settings_my_account", "/my_account",
                  action="my_account", conditions=dict(method=["GET"]))
        m.connect("admin_settings_my_account_update", "/my_account_update",
                  action="my_account_update", conditions=dict(method=["PUT"]))
        m.connect("admin_settings_my_repos", "/my_account/repos",
                  action="my_account_my_repos", conditions=dict(method=["GET"]))
        m.connect("admin_settings_my_pullrequests", "/my_account/pull_requests",
                  action="my_account_my_pullrequests", conditions=dict(method=["GET"]))

    #NOTIFICATION REST ROUTES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/notifications') as m:
        m.connect("notifications", "/notifications",
                  action="create", conditions=dict(method=["POST"]))
        m.connect("notifications", "/notifications",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("notifications_mark_all_read", "/notifications/mark_all_read",
                  action="mark_all_read", conditions=dict(method=["GET"]))
        m.connect("formatted_notifications", "/notifications.{format}",
                  action="index", conditions=dict(method=["GET"]))
        m.connect("new_notification", "/notifications/new",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("formatted_new_notification", "/notifications/new.{format}",
                  action="new", conditions=dict(method=["GET"]))
        m.connect("/notification/{notification_id}",
                  action="update", conditions=dict(method=["PUT"]))
        m.connect("/notification/{notification_id}",
                  action="delete", conditions=dict(method=["DELETE"]))
        m.connect("edit_notification", "/notification/{notification_id}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("formatted_edit_notification",
                  "/notification/{notification_id}.{format}/edit",
                  action="edit", conditions=dict(method=["GET"]))
        m.connect("notification", "/notification/{notification_id}",
                  action="show", conditions=dict(method=["GET"]))
        m.connect("formatted_notification", "/notifications/{notification_id}.{format}",
                  action="show", conditions=dict(method=["GET"]))

    #ADMIN MAIN PAGES
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='admin/admin') as m:
        m.connect('admin_home', '', action='index')
        m.connect('admin_add_repo', '/add_repo/{new_repo:[a-z0-9\. _-]*}',
                  action='add_repo')

    #==========================================================================
    # API V2
    #==========================================================================
    with rmap.submapper(path_prefix=ADMIN_PREFIX,
                        controller='api/api') as m:
        m.connect('api', '/api')

    #USER JOURNAL
    rmap.connect('journal', '%s/journal' % ADMIN_PREFIX,
                 controller='journal', action='index')
    rmap.connect('journal_rss', '%s/journal/rss' % ADMIN_PREFIX,
                 controller='journal', action='journal_rss')
    rmap.connect('journal_atom', '%s/journal/atom' % ADMIN_PREFIX,
                 controller='journal', action='journal_atom')

    rmap.connect('public_journal', '%s/public_journal' % ADMIN_PREFIX,
                 controller='journal', action="public_journal")

    rmap.connect('public_journal_rss', '%s/public_journal/rss' % ADMIN_PREFIX,
                 controller='journal', action="public_journal_rss")

    rmap.connect('public_journal_rss_old', '%s/public_journal_rss' % ADMIN_PREFIX,
                 controller='journal', action="public_journal_rss")

    rmap.connect('public_journal_atom',
                 '%s/public_journal/atom' % ADMIN_PREFIX, controller='journal',
                 action="public_journal_atom")

    rmap.connect('public_journal_atom_old',
                 '%s/public_journal_atom' % ADMIN_PREFIX, controller='journal',
                 action="public_journal_atom")

    rmap.connect('toggle_following', '%s/toggle_following' % ADMIN_PREFIX,
                 controller='journal', action='toggle_following',
                 conditions=dict(method=["POST"]))

    #SEARCH
    rmap.connect('search', '%s/search' % ADMIN_PREFIX, controller='search',)
    rmap.connect('search_repo_admin', '%s/search/{repo_name:.*}' % ADMIN_PREFIX,
                 controller='search',
                 conditions=dict(function=check_repo))
    rmap.connect('search_repo', '/{repo_name:.*?}/search',
                 controller='search',
                 conditions=dict(function=check_repo),
                 )

    #LOGIN/LOGOUT/REGISTER/SIGN IN
    rmap.connect('login_home', '%s/login' % ADMIN_PREFIX, controller='login')
    rmap.connect('logout_home', '%s/logout' % ADMIN_PREFIX, controller='login',
                 action='logout')

    rmap.connect('register', '%s/register' % ADMIN_PREFIX, controller='login',
                 action='register')

    rmap.connect('reset_password', '%s/password_reset' % ADMIN_PREFIX,
                 controller='login', action='password_reset')

    rmap.connect('reset_password_confirmation',
                 '%s/password_reset_confirmation' % ADMIN_PREFIX,
                 controller='login', action='password_reset_confirmation')

    #FEEDS
    rmap.connect('rss_feed_home', '/{repo_name:.*?}/feed/rss',
                controller='feed', action='rss',
                conditions=dict(function=check_repo))

    rmap.connect('atom_feed_home', '/{repo_name:.*?}/feed/atom',
                controller='feed', action='atom',
                conditions=dict(function=check_repo))

    #==========================================================================
    # REPOSITORY ROUTES
    #==========================================================================
    rmap.connect('summary_home', '/{repo_name:.*?}',
                controller='summary',
                conditions=dict(function=check_repo))

    rmap.connect('repo_size', '/{repo_name:.*?}/repo_size',
                controller='summary', action='repo_size',
                conditions=dict(function=check_repo))

    rmap.connect('repos_group_home', '/{group_name:.*}',
                controller='admin/repos_groups', action="show_by_name",
                conditions=dict(function=check_group))

    rmap.connect('changeset_home', '/{repo_name:.*?}/changeset/{revision}',
                controller='changeset', revision='tip',
                conditions=dict(function=check_repo))

    # no longer user, but kept for routes to work
    rmap.connect("_edit_repo", "/{repo_name:.*?}/edit",
                 controller='admin/repos', action="edit",
                 conditions=dict(method=["GET"], function=check_repo)
                 )

    rmap.connect("edit_repo", "/{repo_name:.*?}/settings",
                 controller='admin/repos', action="edit",
                 conditions=dict(method=["GET"], function=check_repo)
                 )

    #still working url for backward compat.
    rmap.connect('raw_changeset_home_depraced',
                 '/{repo_name:.*?}/raw-changeset/{revision}',
                 controller='changeset', action='changeset_raw',
                 revision='tip', conditions=dict(function=check_repo))

    ## new URLs
    rmap.connect('changeset_raw_home',
                 '/{repo_name:.*?}/changeset-diff/{revision}',
                 controller='changeset', action='changeset_raw',
                 revision='tip', conditions=dict(function=check_repo))

    rmap.connect('changeset_patch_home',
                 '/{repo_name:.*?}/changeset-patch/{revision}',
                 controller='changeset', action='changeset_patch',
                 revision='tip', conditions=dict(function=check_repo))

    rmap.connect('changeset_download_home',
                 '/{repo_name:.*?}/changeset-download/{revision}',
                 controller='changeset', action='changeset_download',
                 revision='tip', conditions=dict(function=check_repo))

    rmap.connect('changeset_comment',
                 '/{repo_name:.*?}/changeset/{revision}/comment',
                controller='changeset', revision='tip', action='comment',
                conditions=dict(function=check_repo))

    rmap.connect('changeset_comment_preview',
                 '/{repo_name:.*?}/changeset/comment/preview',
                controller='changeset', action='preview_comment',
                conditions=dict(function=check_repo, method=["POST"]))

    rmap.connect('changeset_comment_delete',
                 '/{repo_name:.*?}/changeset/comment/{comment_id}/delete',
                controller='changeset', action='delete_comment',
                conditions=dict(function=check_repo, method=["DELETE"]))

    rmap.connect('changeset_info', '/changeset_info/{repo_name:.*?}/{revision}',
                 controller='changeset', action='changeset_info')

    rmap.connect('compare_url',
                 '/{repo_name:.*?}/compare/{org_ref_type}@{org_ref:.*?}...{other_ref_type}@{other_ref:.*?}',
                 controller='compare', action='index',
                 conditions=dict(function=check_repo),
                 requirements=dict(
                            org_ref_type='(branch|book|tag|rev|__other_ref_type__)',
                            other_ref_type='(branch|book|tag|rev|__org_ref_type__)')
                 )

    rmap.connect('pullrequest_home',
                 '/{repo_name:.*?}/pull-request/new', controller='pullrequests',
                 action='index', conditions=dict(function=check_repo,
                                                 method=["GET"]))

    rmap.connect('pullrequest',
                 '/{repo_name:.*?}/pull-request/new', controller='pullrequests',
                 action='create', conditions=dict(function=check_repo,
                                                  method=["POST"]))

    rmap.connect('pullrequest_show',
                 '/{repo_name:.*?}/pull-request/{pull_request_id}',
                 controller='pullrequests',
                 action='show', conditions=dict(function=check_repo,
                                                method=["GET"]))
    rmap.connect('pullrequest_update',
                 '/{repo_name:.*?}/pull-request/{pull_request_id}',
                 controller='pullrequests',
                 action='update', conditions=dict(function=check_repo,
                                                method=["PUT"]))
    rmap.connect('pullrequest_delete',
                 '/{repo_name:.*?}/pull-request/{pull_request_id}',
                 controller='pullrequests',
                 action='delete', conditions=dict(function=check_repo,
                                                method=["DELETE"]))

    rmap.connect('pullrequest_show_all',
                 '/{repo_name:.*?}/pull-request',
                 controller='pullrequests',
                 action='show_all', conditions=dict(function=check_repo,
                                                method=["GET"]))

    rmap.connect('pullrequest_comment',
                 '/{repo_name:.*?}/pull-request-comment/{pull_request_id}',
                 controller='pullrequests',
                 action='comment', conditions=dict(function=check_repo,
                                                method=["POST"]))

    rmap.connect('pullrequest_comment_delete',
                 '/{repo_name:.*?}/pull-request-comment/{comment_id}/delete',
                controller='pullrequests', action='delete_comment',
                conditions=dict(function=check_repo, method=["DELETE"]))

    rmap.connect('summary_home_summary', '/{repo_name:.*?}/summary',
                controller='summary', conditions=dict(function=check_repo))

    rmap.connect('shortlog_home', '/{repo_name:.*?}/shortlog',
                controller='shortlog', conditions=dict(function=check_repo))

    rmap.connect('shortlog_file_home', '/{repo_name:.*?}/shortlog/{revision}/{f_path:.*}',
                controller='shortlog', f_path=None,
                conditions=dict(function=check_repo))

    rmap.connect('branches_home', '/{repo_name:.*?}/branches',
                controller='branches', conditions=dict(function=check_repo))

    rmap.connect('tags_home', '/{repo_name:.*?}/tags',
                controller='tags', conditions=dict(function=check_repo))

    rmap.connect('bookmarks_home', '/{repo_name:.*?}/bookmarks',
                controller='bookmarks', conditions=dict(function=check_repo))

    rmap.connect('changelog_home', '/{repo_name:.*?}/changelog',
                controller='changelog', conditions=dict(function=check_repo))

    rmap.connect('changelog_details', '/{repo_name:.*?}/changelog_details/{cs}',
                controller='changelog', action='changelog_details',
                conditions=dict(function=check_repo))

    rmap.connect('files_home', '/{repo_name:.*?}/files/{revision}/{f_path:.*}',
                controller='files', revision='tip', f_path='',
                conditions=dict(function=check_repo))

    rmap.connect('files_home_nopath', '/{repo_name:.*?}/files/{revision}',
                controller='files', revision='tip', f_path='',
                conditions=dict(function=check_repo))

    rmap.connect('files_history_home',
                 '/{repo_name:.*?}/history/{revision}/{f_path:.*}',
                 controller='files', action='history', revision='tip', f_path='',
                 conditions=dict(function=check_repo))

    rmap.connect('files_diff_home', '/{repo_name:.*?}/diff/{f_path:.*}',
                controller='files', action='diff', revision='tip', f_path='',
                conditions=dict(function=check_repo))

    rmap.connect('files_rawfile_home',
                 '/{repo_name:.*?}/rawfile/{revision}/{f_path:.*}',
                 controller='files', action='rawfile', revision='tip',
                 f_path='', conditions=dict(function=check_repo))

    rmap.connect('files_raw_home',
                 '/{repo_name:.*?}/raw/{revision}/{f_path:.*}',
                 controller='files', action='raw', revision='tip', f_path='',
                 conditions=dict(function=check_repo))

    rmap.connect('files_annotate_home',
                 '/{repo_name:.*?}/annotate/{revision}/{f_path:.*}',
                 controller='files', action='index', revision='tip',
                 f_path='', annotate=True, conditions=dict(function=check_repo))

    rmap.connect('files_edit_home',
                 '/{repo_name:.*?}/edit/{revision}/{f_path:.*}',
                 controller='files', action='edit', revision='tip',
                 f_path='', conditions=dict(function=check_repo))

    rmap.connect('files_add_home',
                 '/{repo_name:.*?}/add/{revision}/{f_path:.*}',
                 controller='files', action='add', revision='tip',
                 f_path='', conditions=dict(function=check_repo))

    rmap.connect('files_archive_home', '/{repo_name:.*?}/archive/{fname}',
                controller='files', action='archivefile',
                conditions=dict(function=check_repo))

    rmap.connect('files_nodelist_home',
                 '/{repo_name:.*?}/nodelist/{revision}/{f_path:.*}',
                controller='files', action='nodelist',
                conditions=dict(function=check_repo))

    rmap.connect('repo_fork_create_home', '/{repo_name:.*?}/fork',
                controller='forks', action='fork_create',
                conditions=dict(function=check_repo, method=["POST"]))

    rmap.connect('repo_fork_home', '/{repo_name:.*?}/fork',
                controller='forks', action='fork',
                conditions=dict(function=check_repo))

    rmap.connect('repo_forks_home', '/{repo_name:.*?}/forks',
                 controller='forks', action='forks',
                 conditions=dict(function=check_repo))

    rmap.connect('repo_followers_home', '/{repo_name:.*?}/followers',
                 controller='followers', action='followers',
                 conditions=dict(function=check_repo))

    return rmap