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