init
This commit is contained in:
commit
be2c81dc86
10 changed files with 162 additions and 0 deletions
9
.editorconfig
Normal file
9
.editorconfig
Normal file
|
@ -0,0 +1,9 @@
|
|||
root = true
|
||||
|
||||
[*.cr]
|
||||
charset = utf-8
|
||||
end_of_line = lf
|
||||
insert_final_newline = true
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
trim_trailing_whitespace = true
|
9
.gitignore
vendored
Normal file
9
.gitignore
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
/docs/
|
||||
/lib/
|
||||
/bin/
|
||||
/.shards/
|
||||
*.dwarf
|
||||
|
||||
# Libraries don't need dependency lock
|
||||
# Dependencies will be locked in applications that use them
|
||||
/shard.lock
|
21
LICENSE
Normal file
21
LICENSE
Normal file
|
@ -0,0 +1,21 @@
|
|||
MIT License
|
||||
|
||||
Copyright (c) 2022 Dominic Grimm <dominic.grimm@gmail.com>
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
39
README.md
Normal file
39
README.md
Normal file
|
@ -0,0 +1,39 @@
|
|||
# ldap_escape
|
||||
|
||||
Based on https://github.com/tcort/ldap-escape.
|
||||
|
||||
## Installation
|
||||
|
||||
1. Add the dependency to your `shard.yml`:
|
||||
|
||||
```yaml
|
||||
dependencies:
|
||||
ldap_escape:
|
||||
github: your-github-user/ldap_escape
|
||||
```
|
||||
|
||||
2. Run `shards install`
|
||||
|
||||
## Usage
|
||||
|
||||
```crystal
|
||||
require "ldap_escape"
|
||||
```
|
||||
|
||||
TODO: Write usage instructions here
|
||||
|
||||
## Development
|
||||
|
||||
TODO: Write development instructions here
|
||||
|
||||
## Contributing
|
||||
|
||||
1. Fork it (<https://github.com/your-github-user/ldap_escape/fork>)
|
||||
2. Create your feature branch (`git checkout -b my-new-feature`)
|
||||
3. Commit your changes (`git commit -am 'Add some feature'`)
|
||||
4. Push to the branch (`git push origin my-new-feature`)
|
||||
5. Create a new Pull Request
|
||||
|
||||
## Contributors
|
||||
|
||||
- [Dominic Grimm](https://github.com/your-github-user) - creator and maintainer
|
13
shard.yml
Normal file
13
shard.yml
Normal file
|
@ -0,0 +1,13 @@
|
|||
name: ldap_escape
|
||||
version: 0.1.0
|
||||
|
||||
authors:
|
||||
- Dominic Grimm <dominic.grimm@gmail.com>
|
||||
|
||||
crystal: 1.3.2
|
||||
|
||||
license: MIT
|
||||
|
||||
dependencies:
|
||||
version_from_shard:
|
||||
github: hugopl/version_from_shard
|
15
spec/ldap_escape_spec.cr
Normal file
15
spec/ldap_escape_spec.cr
Normal file
|
@ -0,0 +1,15 @@
|
|||
require "./spec_helper"
|
||||
|
||||
describe LdapEscape do
|
||||
describe "#filter" do
|
||||
it "filters out malicious filter characters" do
|
||||
LdapEscape.filter("\u0000\u0028\u0029\u002a\u005c").should eq "\\00\\28\\29\\2a\\5c"
|
||||
end
|
||||
end
|
||||
|
||||
describe "#dn" do
|
||||
it "filters out malicious dn characters" do
|
||||
LdapEscape.dn("\u0020\u0022\u0023\u002b\u002c\u003b\u003c\u003d\u003e\u005c").should eq "\\\\ \\\"\\#\\+\\,\\;\\<\\=\\>\\\\"
|
||||
end
|
||||
end
|
||||
end
|
2
spec/spec_helper.cr
Normal file
2
spec/spec_helper.cr
Normal file
|
@ -0,0 +1,2 @@
|
|||
require "spec"
|
||||
require "../src/ldap_escape"
|
46
src/ldap_escape.cr
Normal file
46
src/ldap_escape.cr
Normal file
|
@ -0,0 +1,46 @@
|
|||
module LdapEscape
|
||||
extend self
|
||||
|
||||
FILTER = {
|
||||
"\u0000" => "\\00", # null
|
||||
"\u0028" => "\\28", # (
|
||||
"\u0029" => "\\29", # )
|
||||
"\u002a" => "\\2a", # *
|
||||
"\u005c" => "\\5c", # \
|
||||
}
|
||||
FILTER_REGEX = /(\0|\x28|\x29|\x2a|\x5c)/
|
||||
|
||||
DN_BEGIN = {
|
||||
"\u0020" => "\\ ", # space
|
||||
}
|
||||
DN_BEGIN_REGEX = /^(\x20)/
|
||||
|
||||
DN = {
|
||||
"\u0022" => "\\\"", # "
|
||||
"\u0023" => "\\#", # #
|
||||
"\u002b" => "\\+", # +
|
||||
"\u002c" => "\\,", # ,
|
||||
"\u003b" => "\\;", # ;
|
||||
"\u003c" => "\\<", # <
|
||||
"\u003d" => "\\=", # =
|
||||
"\u003e" => "\\>", # >
|
||||
"\u005c" => "\\\\", # \
|
||||
}
|
||||
DN_REGEX = /(\x22|\x23|\x2b|\x2c|\x3b|\x3c|\x3d|\x3e|\x5c)/
|
||||
|
||||
DN_END = {
|
||||
'\u0020' => "\\ ", # space
|
||||
}
|
||||
DN_END_REGEX = /(\x20)$/
|
||||
|
||||
def filter(input : String) : String
|
||||
input.gsub(FILTER_REGEX) { |match| FILTER[match] }
|
||||
end
|
||||
|
||||
def dn(input : String) : String
|
||||
input
|
||||
.gsub(DN_BEGIN_REGEX) { |match| DN_BEGIN[match] }
|
||||
.gsub(DN_REGEX) { |match| DN[match] }
|
||||
.gsub(DN_END_REGEX) { |match| DN_END[match] }
|
||||
end
|
||||
end
|
5
src/ldap_escape/version.cr
Normal file
5
src/ldap_escape/version.cr
Normal file
|
@ -0,0 +1,5 @@
|
|||
require "version_from_shard"
|
||||
|
||||
module LdapEscape
|
||||
VersionFromShard.declare
|
||||
end
|
3
test.cr
Normal file
3
test.cr
Normal file
|
@ -0,0 +1,3 @@
|
|||
require "./src/ldap_escape"
|
||||
|
||||
p! LdapEscape.dn("\u0020\u0022\u0023\u002b\u002c\u003b\u003c\u003d\u003e\u005c")
|
Loading…
Reference in a new issue